“Baby Mental Life: Study 2” was conducted on MTurk on 2018-08-04.

Our planned sample was 300 participants, and we anticipated that roughly 80% of recruited participants would pass all of our attention checks, so we initially recruited 378 participants (on the idea that ~80% of 378 ~ 300 participants; note that for administrative purposes we need to recuit participants in batches that were divisible by 9). After filtering out participants who failed at least one of our attention checks, we ended up retaining fewer than 300 participants, so we recruited an additional 16 participants for a total of 394 people recruited. At each stage, we recruited women and men through separate studies, in hopes of acquiring a roughly equal split between genders.

In the end, we ended up with a sample of 304 participants who passed our attention checks, 237 of whom came from unique GPS coordinates.

For this first pass, these data exclude participants where there is another participant with an identical set of GPS coordinates as recorded by Qualtrics.

Each participant assessed children’s mental capacities at 13 target ages between the ages of 0 and 5 years. For each target, they rated 20 mental capacities on a scale from 0 (not at all capable) to 100 (completely capable).

For more details about the study, see our preregistration here.

# load required libraries
library(tidyverse)
── Attaching packages ─────────────────────────────────────── tidyverse 1.2.1 ──
✔ ggplot2 3.0.0     ✔ purrr   0.2.5
✔ tibble  1.4.2     ✔ dplyr   0.7.6
✔ tidyr   0.8.1     ✔ stringr 1.3.1
✔ readr   1.1.1     ✔ forcats 0.3.0
── Conflicts ────────────────────────────────────────── tidyverse_conflicts() ──
✖ dplyr::filter() masks stats::filter()
✖ dplyr::lag()    masks stats::lag()
library(langcog) # source: https://github.com/langcog/langcog-package

Attaching package: ‘langcog’

The following object is masked from ‘package:base’:

    scale
library(psych)

Attaching package: ‘psych’

The following objects are masked from ‘package:ggplot2’:

    %+%, alpha
library(lme4)
Loading required package: Matrix

Attaching package: ‘Matrix’

The following object is masked from ‘package:tidyr’:

    expand
# set theme for ggplots
theme_set(theme_bw())
chosen_rot <- "oblimin"
# run source code (extra home-made functions)
source("./scripts/max_factors_efa.R")
source("./scripts/plot_fun.R")
source("./scripts/reten_fun.R")
source("./scripts/data_prep.R")
NAs introduced by coercionattributes are not identical across measure variables;
they will be droppedJoining, by = "question_qualtrics"

Study 1 EFA

# load in EFA results from study 1
efa_S1 <- readRDS("../study 1/s1_efa.rds")
heatmap_fun(efa_S1) + 
  labs(title = paste0("STUDY 1 Parallel Analysis (rotation: ", chosen_rot, ")"),
       subtitle = "'% var.' indicates the amount of shared variance explained (total = 100%)")
Joining, by = "capacity"
Joining, by = "factor"

EFA

To test H1, we planned to conduct an exploratory factor analysis (EFA) collapsing across all 13 target characters (and treating an individual participant’s responses to each character as if they were independent data points) - see the preregistration for more details.

As with Study 1, we planned to examine three factor retention protocols in order to determine how many factors to retain: Parallel analysis, minimizing BIC, and a set of preset criteria outlined in Weisman et al. (2017). Here we look at each solution in turn.

We predicted that we’d see a similar factor structure to that found in Study 1.

Rotation choices

We planned to examine oblimin-rotated solutions (which allow factors to correlate), but you could examine other rotation options by selecting a different rotation type here.

chosen_rot <- "oblimin" # preregistered: factors allowed to correlate
# chosen_rot <- "varimax" # orthogonal: factors forced not to correlate
# chosen_rot <- "none" # no rotation

Parallel analysis

How many factors to retain?

reten_all_PA <- fa.parallel(d_all, plot = F); reten_all_PA
Parallel analysis suggests that the number of factors =  4  and the number of components =  4 
Call: fa.parallel(x = d_all, plot = F)
Parallel analysis suggests that the number of factors =  4  and the number of components =  4 

 Eigen Values of 
reten_all_par <- reten_all_PA$nfact

What are these factors?

efa_all_par <- fa(d_all, nfactors = reten_all_par, rotate = chosen_rot,
                  scores = "tenBerge", impute = "median")
Loading required namespace: GPArotation
heatmap_fun(efa_all_par) + 
  labs(title = paste0("Parallel Analysis (rotation: ", chosen_rot, ")"),
       subtitle = "'% var.' indicates the amount of shared variance explained (total = 100%)")
Joining, by = "capacity"
Joining, by = "factor"

These factors look extremely similar to what we saw in Study 1 (see above). I (Kara) would say that H1 is strongly supported.

Which capacities are attributed to which targets?

We could look at factor scores using the Study 2 EFA to see which capacities were attributed to which targets. This is not the primary way we planned to investigate this - this was listed as a “follow-up analysis” - but I’m putting it here so that it’s in close proximity to the EFA results for ease of interpretation.

Age as numeric (raw)

scoresplot_fun(efa_all_par, target = "all (study 2)", 
               target_encoding = "numeric") +
  scale_x_continuous(breaks = seq(0, 60, 12)) +
  labs(title = "Parallel Analysis") +
  theme(axis.text.x = element_text(angle = 45, hjust = 1, vjust = 1))
Ignoring unknown aesthetics: y

Age as numeric (square-root-transformed)

scoresplot_fun(efa_all_par, target = "all (study 2)", 
               target_encoding = "numeric") +
  scale_x_continuous(breaks = seq(0, 60, 12), trans = "sqrt") +
  labs(title = "Parallel Analysis", 
       x = "age after square-root transformation (months)") +
  theme(axis.text.x = element_text(angle = 45, hjust = 1, vjust = 1))
Ignoring unknown aesthetics: y

Age as ordinal

scoresplot_fun(efa_all_par, target = "all (study 2)", 
               target_encoding = "ordinal") +
  labs(title = "Parallel Analysis", 
       x = "age (ordinal)") +
  theme(axis.text.x = element_text(angle = 45, hjust = 1, vjust = 1))
Ignoring unknown aesthetics: y

And here’s a close look at all of the raw data (color-coded according to the Study 2 EFA results):

itemsplot_fun(efa_all_par, target = "all (study 2)") + 
  labs(title = "Parallel Analysis")
Joining, by = "capacity"

|=================================                     | 63% ~1 s remaining     
|==================================                    | 65% ~1 s remaining     
|===================================                   | 66% ~1 s remaining     
|====================================                  | 68% ~1 s remaining     
|=====================================                 | 70% ~1 s remaining     
|======================================                | 71% ~1 s remaining     
|=======================================               | 73% ~1 s remaining     
|========================================              | 75% ~1 s remaining     
|=========================================             | 76% ~1 s remaining     
|==========================================            | 78% ~1 s remaining     
|==========================================            | 80% ~1 s remaining     
|============================================          | 82% ~1 s remaining     
|=============================================         | 83% ~1 s remaining     
|=============================================         | 85% ~0 s remaining     
|==============================================        | 87% ~0 s remaining     
|===============================================       | 88% ~0 s remaining     
|================================================      | 90% ~0 s remaining     
|=================================================     | 92% ~0 s remaining     
|==================================================    | 93% ~0 s remaining     
|===================================================   | 95% ~0 s remaining     
|====================================================  | 97% ~0 s remaining     
|===================================================== | 99% ~0 s remaining     
Joining, by = c("capacity", "factor", "order")

d_all %>%
  rownames_to_column("subid_target") %>%
  mutate(subid = gsub("_.*$", "", subid_target),
         target = gsub("^.*_", "", subid_target),
         target_num = recode(target,
                             "target00mo" = 0,
                             "target0Xmo" = 4/30,
                             "target01mo" = 1,
                             "target02mo" = 2,
                             "target04mo" = 4,
                             "target06mo" = 6,
                             "target09mo" = 9,
                             "target12mo" = 12,
                             "target18mo" = 18,
                             "target24mo" = 24,
                             "target36mo" = 36,
                             "target48mo" = 48,
                             "target60mo" = 60),
         target_ord = recode_factor(target,
                                    "target00mo" = "newborns",
                                    "target0Xmo" = "4-day-olds",
                                    "target01mo" = "1-month-olds",
                                    "target02mo" = "2-month-olds",
                                    "target04mo" = "4-month-olds",
                                    "target06mo" = "6-month-olds",
                                    "target09mo" = "9-month-olds",
                                    "target12mo" = "12-month-olds",
                                    "target18mo" = "18-month-olds",
                                    "target24mo" = "2-year-olds",
                                    "target36mo" = "3-year-olds",
                                    "target48mo" = "4-year-olds",
                                    "target60mo" = "5-year-olds")) %>%
  select(-c(subid_target, target)) %>%
  gather(capacity, response, -c(subid, starts_with("target"))) %>%
  full_join(efa_all_par$loadings[] %>%
              data.frame() %>%
              rownames_to_column("capacity") %>%
              gather(factor, loading, -capacity) %>%
              group_by(capacity) %>%
              top_n(1, abs(loading)) %>%
              ungroup() %>%
              arrange(factor, desc(abs(loading))) %>%
              mutate(order = 1:20) %>%
              select(capacity, factor, order)) %>%
  # ggplot(aes(x = target_ord, y = response, color = factor)) +
  ggplot(aes(x = target_num, y = response, color = factor)) +
  facet_wrap(~ reorder(capacity, order)) +
  geom_line(aes(group = subid), alpha = 0.1) +
  geom_smooth(aes(group = capacity),
              method = "lm", formula = "y ~ poly(x, 3)",
              color = "black") +
  scale_color_brewer(palette = "Set2", guide = "none") +
  # scale_x_discrete("target age (ordinal)") +
  scale_x_continuous("target age (months)", breaks = seq(0, 60, 12)) +
  # scale_x_continuous("age after square-root transformation (months)", 
  #                    breaks = seq(0, 60, 12), trans = "sqrt") +
  theme(axis.text.x = element_text(angle = 45, hjust = 1, vjust = 1)) +
  guides(color = guide_legend(override.aes = list(alpha = 1)))
Joining, by = "capacity"

Minimizing BIC

How many factors to retain?

reten_all_vss <- VSS(d_all, plot = F); reten_all_vss

Very Simple Structure
Call: vss(x = x, n = n, rotate = rotate, diagonal = diagonal, fm = fm, 
    n.obs = n.obs, plot = plot, title = title, use = use, cor = cor)
VSS complexity 1 achieves a maximimum of 0.85  with  1  factors
VSS complexity 2 achieves a maximimum of 0.95  with  2  factors

The Velicer MAP achieves a minimum of 0.02  with  4  factors 
BIC achieves a minimum of  -205.41  with  8  factors
Sample Size adjusted BIC achieves a minimum of  -21.12  with  8  factors

Statistics by number of factors 
reten_all_bic <- data.frame(reten_all_vss$vss.stats %>%
  rownames_to_column("nfactors") %>%
  top_n(-1, BIC) %>%
  select(nfactors))$nfactors %>% as.numeric()

What are these factors?

efa_all_bic <- fa(d_all, nfactors = reten_all_bic, rotate = chosen_rot,
                  scores = "tenBerge", impute = "median")
convergence not obtained in GPFoblq. 1000 iterations used.
heatmap_fun(efa_all_bic) + 
  labs(title = paste0("Minimizing BIC (rotation: ", chosen_rot, ")"),
       subtitle = "'% var.' indicates the amount of shared variance explained (total = 100%)")
Joining, by = "capacity"
Joining, by = "factor"

A more complex picture, but the first 4 factors look similar to what we get through parallel analysis. (I think something similar happened with Study 1, but we should go back and compare.)

Which capacities are attributed to which targets?

scoresplot_fun(efa_all_bic, target = "all (study 2)") + 
  labs(title = "Minimizing BIC") +
  theme(axis.text.x = element_text(angle = 45, hjust = 1, vjust = 1))
Ignoring unknown aesthetics: y

We’ll skip regression analyses and other plots for now.

Preset retention criteria

How many factors to retain?

reten_all_k <- reten_fun(d_all, rot_type = chosen_rot)
print(paste("Preset criteria suggest retaining", reten_all_k, "factors"))
[1] "Preset criteria suggest retaining 4 factors"

This gives the same solution as parallel analysis - 4 factors :)

Projecting into Study 1 factor space

I (Kara) made a big mistake in thinking through this: I thought we could project a 20-variable dataset into a 60-variable dataset using the predict.psych() function, but we can’t!

I’ve tried to hack together a way to do this, by replacing all missing values at random (either within the full range of the scale, or around the midpoint, or near 0) - but I haven’t gotten anything to work. As you can see below (replacing missing values at random between 0-5), you see slight increases across all factors, and the most dramatic increase for Factor 4 - but I think this is because that factor is least well-defined in the Study 1 EFA solution? I think we need to focus on analyzing factor scores from our Study 2 EFA. I’m sorry for this mistake!

extra_var <- rownames(efa_S1$loadings)[!rownames(efa_S1$loadings) %in% rownames(efa_all_par$loadings)]
temp <- d_all %>%
  rownames_to_column("subid") %>%
  mutate(being_afraid_of_somebody = round(runif(3081, 0, 5)), 
         being_angry_at_somebody = round(runif(3081, 0, 5)),
         being_aware_of_things = round(runif(3081, 0, 5)), 
         being_comforted_by_physical_touch = round(runif(3081, 0, 5)),
         calming_themselves_down = round(runif(3081, 0, 5)), 
         detecting_danger = round(runif(3081, 0, 5)), 
         feeling_annoyed = round(runif(3081, 0, 5)), 
         feeling_bored = round(runif(3081, 0, 5)), 
         feeling_calm = round(runif(3081, 0, 5)),
         feeling_confused = round(runif(3081, 0, 5)), 
         feeling_embarrassed = round(runif(3081, 0, 5)), 
         feeling_guilty = round(runif(3081, 0, 5)),
         feeling_hopeless = round(runif(3081, 0, 5)), 
         feeling_loved = round(runif(3081, 0, 5)), 
         feeling_neglected = round(runif(3081, 0, 5)),
         feeling_pleasure = round(runif(3081, 0, 5)), 
         feeling_pride = round(runif(3081, 0, 5)), 
         feeling_sad = round(runif(3081, 0, 5)),
         feeling_safe = round(runif(3081, 0, 5)), 
         feeling_scared = round(runif(3081, 0, 5)), 
         feeling_textures = round(runif(3081, 0, 5)),
         feeling_thirsty = round(runif(3081, 0, 5)), 
         feeling_too_hot_or_too_cold = round(runif(3081, 0, 5)),
         feeling_worried = round(runif(3081, 0, 5)), 
         focusing_on_a_goal = round(runif(3081, 0, 5)), 
         getting_angry = round(runif(3081, 0, 5)),
         getting_hurt_feelings = round(runif(3081, 0, 5)), 
         getting_pleasure_from_music = round(runif(3081, 0, 5)),
         having_goals = round(runif(3081, 0, 5)), 
         having_thoughts = round(runif(3081, 0, 5)), 
         having_wants_and_desires = round(runif(3081, 0, 5)),
         imagining_things = round(runif(3081, 0, 5)), 
         listening_to_somebody = round(runif(3081, 0, 5)), 
         making_choices = round(runif(3081, 0, 5)),
         recognizing_others_emotions = round(runif(3081, 0, 5)), 
         recognizing_somebody_else = round(runif(3081, 0, 5)),
         remembering_things = round(runif(3081, 0, 5)), 
         seeing = round(runif(3081, 0, 5)), 
         thinking_before_they_act = round(runif(3081, 0, 5)),
         understanding_what_somebody_else_is_thinking = round(runif(3081, 0, 5))) %>%
  column_to_rownames("subid")
scores_project <- predict.psych(object = efa_S1, data = temp)
scores_project %>%
  data.frame() %>%
  rownames_to_column("subid_target") %>%
  mutate(subid = gsub("_.*$", "", subid_target),
         target = gsub("^.*_", "", subid_target),
         target_num = recode(target,
                             "target00mo" = 0,
                             "target0Xmo" = round(4/30, 3),
                             "target01mo" = 1,
                             "target02mo" = 2,
                             "target04mo" = 4,
                             "target06mo" = 6,
                             "target09mo" = 9,
                             "target12mo" = 12,
                             "target18mo" = 18,
                             "target24mo" = 24,
                             "target36mo" = 36,
                             "target48mo" = 48,
                             "target60mo" = 60),
         target_ord = recode_factor(target,
                                    "target00mo" = "newborns",
                                    "target0Xmo" = "4-day-olds",
                                    "target01mo" = "1-month-olds",
                                    "target02mo" = "2-month-olds",
                                    "target04mo" = "4-month-olds",
                                    "target06mo" = "6-month-olds",
                                    "target09mo" = "9-month-olds",
                                    "target12mo" = "12-month-olds",
                                    "target18mo" = "18-month-olds",
                                    "target24mo" = "2-year-olds",
                                    "target36mo" = "3-year-olds",
                                    "target48mo" = "4-year-olds",
                                    "target60mo" = "5-year-olds")) %>%
  select(-subid_target) %>%
  gather(factor, score, -c(subid, starts_with("target"))) %>%
  ggplot(aes(x = target_num, y = score, color = factor)) +
  facet_grid(~ factor) +
  geom_line(aes(group = subid), alpha = 0.1) +
  scale_x_continuous(breaks = seq(0, 60, 12)) +
  theme(axis.text.x = element_text(angle = 45, hjust = 1, vjust = 1),
        legend.position = "none") +
  labs(title = "Kara's attempt to project into the Study 1 space",
       subtitle = "Replaced all missing values (40 per participant) with a random integer between 0-5",
       x = "target age (months)", y = "factor score")

Regression models in Study 2 factor space

Here’s a multilevel linear regression on these factor scores, with random intercepts and slopes (for target and factor) by participant. Target is coded as numeric, with only the linear contrast.

efa_all_par_scores <- efa_all_par$scores[] %>%
  data.frame() %>%
  rownames_to_column("subid") %>%
  mutate(target = gsub("^.*_target", "target", subid),
         ResponseId = gsub("_target.*$", "", subid),
         target_num = recode(target,
                             "target00mo" = 0,
                             "target0Xmo" = round(4/30, 3),
                             "target01mo" = 1,
                             "target02mo" = 2,
                             "target04mo" = 4,
                             "target06mo" = 6,
                             "target09mo" = 9,
                             "target12mo" = 12,
                             "target18mo" = 18,
                             "target24mo" = 24,
                             "target36mo" = 36,
                             "target48mo" = 48,
                             "target60mo" = 60),
         target_ord = recode_factor(target,
                                    "target00mo" = "newborns",
                                    "target0Xmo" = "4-day-olds",
                                    "target01mo" = "1-month-olds",
                                    "target02mo" = "2-month-olds",
                                    "target04mo" = "4-month-olds",
                                    "target06mo" = "6-month-olds",
                                    "target09mo" = "9-month-olds",
                                    "target12mo" = "12-month-olds",
                                    "target18mo" = "18-month-olds",
                                    "target24mo" = "2-year-olds",
                                    "target36mo" = "3-year-olds",
                                    "target48mo" = "4-year-olds",
                                    "target60mo" = "5-year-olds")) %>%
  select(-subid, -target) %>%
  gather(factor, score, -starts_with("target"), -ResponseId) %>%
  mutate_at(vars(factor), funs(factor))
contrasts(efa_all_par_scores$factor) <- contr.sum(reten_all_par)
# r_all_par <- lmer(score ~ target_num * factor
#                   + (target_num + factor | ResponseId),
#                   efa_all_par_scores)
# summary(r_all_par, corr = F)

If we try to run the model above (our planned analysis), we get an error: “Model is nearly unidentifiable: very large eigenvalue.” The error suggests rescaling variables, which solves the problem. Here I’ve re-scaled by divided age in months by 12, to get age in years. Let’s make sure to talk about this.

r_all_par_rescaled <- lmer(score ~ target_num * factor
                           + (target_num + factor | ResponseId),
                           efa_all_par_scores %>%
                             mutate(target_num = target_num/12))
summary(r_all_par_rescaled, corr = F)
Linear mixed model fit by REML ['lmerMod']
Formula: score ~ target_num * factor + (target_num + factor | ResponseId)
   Data: efa_all_par_scores %>% mutate(target_num = target_num/12)

REML criterion at convergence: 22685.5

Scaled residuals: 
    Min      1Q  Median      3Q     Max 
-9.4103 -0.4328  0.0506  0.5125  5.3546 

Random effects:
 Groups     Name        Variance Std.Dev. Corr                   
 ResponseId (Intercept) 0.3465   0.5887                          
            target_num  0.0164   0.1281   -0.73                  
            factor1     0.1932   0.4396    0.49 -0.40            
            factor2     0.2302   0.4798   -0.66  0.56 -0.41      
            factor3     0.2578   0.5077    0.24  0.00 -0.21 -0.61
 Residual               0.2908   0.5393                          
Number of obs: 12324, groups:  ResponseId, 237

Fixed effects:
                    Estimate Std. Error t value
(Intercept)        -0.393496   0.038790 -10.144
target_num          0.278856   0.008870  31.437
factor1             0.084232   0.030704   2.743
factor2            -0.297423   0.033149  -8.972
factor3             0.265225   0.034858   7.609
target_num:factor1 -0.059692   0.005336 -11.187
target_num:factor2  0.210773   0.005336  39.501
target_num:factor3 -0.187955   0.005336 -35.224

As we predicted (H2), we see dramatic increases in mental capacity attributions across the age range (main effect of target_num).

And also as we predicted (H1), we see differences across factors in where newborns are perceived to start off: Relative to the grand mean, newborns are perceived to start off with more “negative emotions” (distress, frustration, etc.; main effect of factor1), less/fewer capacities in the domain of “cognition and control” (emotional control, self control, etc.; main effect of factor2), and relatively more “bodily sensations” (pain, fatigue, etc.; main effect of factor3). (We could recode this to look at factor4, or just eyeball it from the plot.) Also as predicted, we see that the perceived changes across age vary dramatically across factors: “negative emotions” are perceived to change relatively less over development, “cognition and control” are perceived to change much more over development, and “bodily sensations” are predicted to chagne relatively less.

This is all very much in line with our preregistered hypotheses :)

Now let’s see what the polynomial effects look like (again, looking at age in years instead of months). As we expected, including all of the polynomial effects as random slopes caused the model not to converge (I think we must be calculating df wrong), so I implemented our preregistered remedy and included only the linear effect as a random slope.

# adding polynomial effects
r_all_par_poly <- lmer(score ~ poly(target_num, 3) * factor
                       + (poly(target_num, 1) + factor | ResponseId),
                       efa_all_par_scores %>%
                         mutate(target_num = target_num/12))
summary(r_all_par_poly, corr = F)
Linear mixed model fit by REML ['lmerMod']
Formula: score ~ poly(target_num, 3) * factor + (poly(target_num, 1) +  
    factor | ResponseId)
   Data: efa_all_par_scores %>% mutate(target_num = target_num/12)

REML criterion at convergence: 20140.4

Scaled residuals: 
     Min       1Q   Median       3Q      Max 
-10.3531  -0.4619   0.0027   0.5298   5.8874 

Random effects:
 Groups     Name                Variance Std.Dev. Corr                   
 ResponseId (Intercept)           0.2260  0.4754                         
            poly(target_num, 1) 516.2740 22.7217  -0.51                  
            factor1               0.1966  0.4434   0.45 -0.39            
            factor2               0.2336  0.4833  -0.60  0.55 -0.41      
            factor3               0.2611  0.5110   0.29  0.00 -0.22 -0.61
 Residual                         0.2326  0.4823                         
Number of obs: 12324, groups:  ResponseId, 237

Fixed effects:
                               Estimate Std. Error t value
(Intercept)                   3.909e-15  3.119e-02   0.000
poly(target_num, 3)1          4.881e+01  1.553e+00  31.437
poly(target_num, 3)2         -2.006e+01  4.823e-01 -41.584
poly(target_num, 3)3          9.029e+00  4.823e-01  18.721
factor1                       4.307e-15  2.977e-02   0.000
factor2                      -2.640e-15  3.228e-02   0.000
factor3                      -3.013e-15  3.403e-02   0.000
poly(target_num, 3)1:factor1 -1.045e+01  8.353e-01 -12.509
poly(target_num, 3)2:factor1  3.285e+00  8.353e-01   3.932
poly(target_num, 3)3:factor1 -1.259e+00  8.353e-01  -1.507
poly(target_num, 3)1:factor2  3.690e+01  8.353e-01  44.167
poly(target_num, 3)2:factor2  2.350e+00  8.353e-01   2.814
poly(target_num, 3)3:factor2 -6.747e+00  8.353e-01  -8.077
poly(target_num, 3)1:factor3 -3.290e+01  8.353e-01 -39.386
poly(target_num, 3)2:factor3  1.113e+01  8.353e-01  13.327
poly(target_num, 3)3:factor3 -5.075e+00  8.353e-01  -6.075

Correlation matrix not shown by default, as p = 16 > 12.
Use print(x, correlation=TRUE)  or
     vcov(x)     if you need it

Lots to sift through here, but in general we see that the effect of target age on mental capacity attributions definitely has linear, quadratic, and cubic components, all three of which seem to vary substantially across factors. Pretty much all of these differences are “significant” (if you consider |t| > 2 to be “significant”) - for interpretation, I would need to look closer at the plot. Let’s pull it up again here, with blue lines approximating the formula y ~ poly(x, 3):

scoresplot_fun(efa_all_par, target = "all (study 2)", 
               target_encoding = "numeric") +
  scale_x_continuous("age (months)", breaks = seq(0, 60, 12)) +
  geom_smooth(method = "lm", formula = "y ~ poly(x, 3)",
              color = "blue", size = 2)
Ignoring unknown aesthetics: y

We can talk through these interpretations together - but I find the difference between Factor 2 (“cognition & control”) and Factor 4 (“positive emotions”) to be especially interesting!

Demographics

ggplot(d_demo, aes(x = Duration/60)) + 
  geom_histogram(binwidth = 2) +
  geom_vline(xintercept = median(d_demo$Duration/60), color = "blue", lty = 2) +
  scale_x_continuous(breaks = seq(0, 10000, 4)) +
  labs(title = "Duration of study (according to Qualtrics)",
       subtitle = "Blue dotted line marks median",
       x = "Duration (in minutes)",
       y = "Number of participants")

ggplot(d_demo, aes(x = Age)) + 
  geom_histogram(binwidth = 2) +
  geom_vline(xintercept = median(d_demo$Age), color = "blue", lty = 2) +
  scale_x_continuous(breaks = seq(0, 10000, 4)) +
  labs(title = "Particpiant age (self-reported)",
       subtitle = "Blue dotted line marks median",
       x = "Age (in years)",
       y = "Number of participants")

ggplot(d_demo, aes(x = GenderSex)) + 
  geom_bar() +
  labs(title = "Particpiant gender/sex (self-reported)",
       x = "Gender/sex",
       y = "Number of participants")

ggplot(d_demo, aes(x = gsub('(.{1,30})(\\s|$)', '\\1\n', RaceEthnicity_collapse))) + 
  geom_bar() +
  theme(axis.text.x = element_text(angle = 45, hjust = 1, vjust = 1)) +
  labs(title = "Particpiant race/ethnicity (self-reported)",
       x = "Race/ethnicity",
       y = "Number of participants")

ggplot(d_demo, aes(x = FirstLang)) + 
  geom_bar() +
  labs(title = "Particpiant first language (self-reported)",
       x = "Language",
       y = "Number of participants")

ggplot(d_demo, aes(x = factor(Education,
                              levels = levels(d$Education),
                              labels = gsub('(.{1,30})(\\s|$)', '\\1\n', 
                                            levels(d$Education))))) + 
  geom_bar() +
  theme(axis.text.x = element_text(angle = 45, hjust = 1, vjust = 1)) +
  labs(title = "Particpiant educational attainment (self-reported)",
       x = "Highest level of education completed",
       y = "Number of participants")

ggplot(d_demo, aes(x = Income)) + 
  geom_bar() +
  theme(axis.text.x = element_text(angle = 45, hjust = 1, vjust = 1)) +
  labs(title = "Particpiant household income (self-reported)",
       x = "Annual household income",
       y = "Number of participants")

ggplot(d_demo, aes(x = HouseholdSize)) + 
  geom_histogram(binwidth = 1) +
  geom_vline(xintercept = median(d_demo$HouseholdSize), color = "blue", lty = 2) +
  scale_x_continuous(breaks = seq(0, 10000, 1)) +
  labs(title = "Particpiant household size (self-reported)",
       subtitle = "Blue dotted line marks median",
       x = "Number of people in household (adults and children)",
       y = "Number of participants")

ggplot(d_demo, aes(x = MaritalStatus)) + 
  geom_bar() +
  theme(axis.text.x = element_text(angle = 45, hjust = 1, vjust = 1)) +
  labs(title = "Particpiant marital status (self-reported)",
       x = "Marital status",
       y = "Number of participants")

ggplot(d_demo, aes(x = Parent)) + 
  geom_bar() +
  theme(axis.text.x = element_text(angle = 45, hjust = 1, vjust = 1)) +
  labs(title = "Particpiant parent status (self-reported)",
       subtitle = "'NA' indicates response of 'Prefer not to say'",
       x = "Parent status",
       y = "Number of participants")

ggplot(d_demo %>% filter(Parent == "Yes"), aes(x = ChildrenNumber)) + 
  geom_histogram(binwidth = 1) +
  geom_vline(xintercept = median(d_demo[d_demo$Parent == "Yes",]$ChildrenNumber, na.rm = T), 
             color = "blue", lty = 2) +
  scale_x_continuous(breaks = seq(0, 10000, 1)) +
  labs(title = "Number of children among parents (self-reported)",
       subtitle = "Blue dotted line marks median",
       x = "Number of children (among parents)",
       y = "Number of participants")

ggplot(d_demo %>% filter(Parent == "Yes"), 
       aes(x = factor(ChildrenOldestAge_collapse,
                      levels = levels(d_demo$ChildrenOldestAge_collapse),
                      labels = gsub('(.{1,30})(\\s|$)', '\\1\n', 
                                    levels(d_demo$ChildrenOldestAge_collapse))))) + 
  geom_bar() +
  theme(axis.text.x = element_text(angle = 45, hjust = 1, vjust = 1)) +
  labs(title = "Age of oldest child among parents (self-reported)",
       x = "Age of child in years (among parents)",
       y = "Number of participants")

ggplot(d_demo %>% filter(Parent == "Yes"), 
       aes(x = factor(ChildrenYoungestAge_collapse,
                      levels = levels(d_demo$ChildrenYoungestAge_collapse),
                      labels = gsub('(.{1,30})(\\s|$)', '\\1\n', 
                                    levels(d_demo$ChildrenYoungestAge_collapse))))) + 
  geom_bar() +
  theme(axis.text.x = element_text(angle = 45, hjust = 1, vjust = 1)) +
  labs(title = "Age of youngest child among parents (self-reported)",
       x = "Age of child in years (among parents)",
       y = "Number of participants")

LS0tCnRpdGxlOiAiQmFieSBNZW50YWwgTGlmZTogU3R1ZHkgMiIKc3VidGl0bGU6ICJQcmVyZWdpc3RlcmVkIGFuYWx5c2VzIgpkYXRlOiAyMDE4LTA5LTA1Cm91dHB1dDogCiAgaHRtbF9ub3RlYm9vazoKICAgIHRvYzogdHJ1ZQogICAgdG9jX2Zsb2F0OiB0cnVlCi0tLQoKIkJhYnkgTWVudGFsIExpZmU6IFN0dWR5IDIiIHdhcyBjb25kdWN0ZWQgb24gTVR1cmsgb24gMjAxOC0wOC0wNC4KCk91ciBwbGFubmVkIHNhbXBsZSB3YXMgMzAwIHBhcnRpY2lwYW50cywgYW5kIHdlIGFudGljaXBhdGVkIHRoYXQgcm91Z2hseSA4MCUgb2YgcmVjcnVpdGVkIHBhcnRpY2lwYW50cyB3b3VsZCBwYXNzIGFsbCBvZiBvdXIgYXR0ZW50aW9uIGNoZWNrcywgc28gd2UgaW5pdGlhbGx5IHJlY3J1aXRlZCAzNzggcGFydGljaXBhbnRzIChvbiB0aGUgaWRlYSB0aGF0IH44MCUgb2YgMzc4IH4gMzAwIHBhcnRpY2lwYW50czsgbm90ZSB0aGF0IGZvciBhZG1pbmlzdHJhdGl2ZSBwdXJwb3NlcyB3ZSBuZWVkIHRvIHJlY3VpdCBwYXJ0aWNpcGFudHMgaW4gYmF0Y2hlcyB0aGF0IHdlcmUgZGl2aXNpYmxlIGJ5IDkpLiBBZnRlciBmaWx0ZXJpbmcgb3V0IHBhcnRpY2lwYW50cyB3aG8gZmFpbGVkIGF0IGxlYXN0IG9uZSBvZiBvdXIgYXR0ZW50aW9uIGNoZWNrcywgd2UgZW5kZWQgdXAgcmV0YWluaW5nIGZld2VyIHRoYW4gMzAwIHBhcnRpY2lwYW50cywgc28gd2UgcmVjcnVpdGVkIGFuIGFkZGl0aW9uYWwgMTYgcGFydGljaXBhbnRzIGZvciBhIHRvdGFsIG9mIDM5NCBwZW9wbGUgcmVjcnVpdGVkLiBBdCBlYWNoIHN0YWdlLCB3ZSByZWNydWl0ZWQgd29tZW4gYW5kIG1lbiB0aHJvdWdoIHNlcGFyYXRlIHN0dWRpZXMsIGluIGhvcGVzIG9mIGFjcXVpcmluZyBhIHJvdWdobHkgZXF1YWwgc3BsaXQgYmV0d2VlbiBnZW5kZXJzLgoKSW4gdGhlIGVuZCwgd2UgZW5kZWQgdXAgd2l0aCBhIHNhbXBsZSBvZiAzMDQgcGFydGljaXBhbnRzIHdobyBwYXNzZWQgb3VyIGF0dGVudGlvbiBjaGVja3MsIDIzNyBvZiB3aG9tIGNhbWUgZnJvbSB1bmlxdWUgR1BTIGNvb3JkaW5hdGVzLgoKKipGb3IgdGhpcyBmaXJzdCBwYXNzLCB0aGVzZSBkYXRhIF9leGNsdWRlXyBwYXJ0aWNpcGFudHMgd2hlcmUgdGhlcmUgaXMgYW5vdGhlciBwYXJ0aWNpcGFudCB3aXRoIGFuIGlkZW50aWNhbCBzZXQgb2YgR1BTIGNvb3JkaW5hdGVzIGFzIHJlY29yZGVkIGJ5IFF1YWx0cmljcy4qKgoKRWFjaCBwYXJ0aWNpcGFudCBhc3Nlc3NlZCBjaGlsZHJlbidzIG1lbnRhbCBjYXBhY2l0aWVzIGF0IDEzIHRhcmdldCBhZ2VzIGJldHdlZW4gdGhlIGFnZXMgb2YgMCBhbmQgNSB5ZWFycy4gRm9yIGVhY2ggdGFyZ2V0LCB0aGV5IHJhdGVkIDIwIG1lbnRhbCBjYXBhY2l0aWVzIG9uIGEgc2NhbGUgZnJvbSAwIChub3QgYXQgYWxsIGNhcGFibGUpIHRvIDEwMCAoY29tcGxldGVseSBjYXBhYmxlKS4gCgpGb3IgbW9yZSBkZXRhaWxzIGFib3V0IHRoZSBzdHVkeSwgc2VlIG91ciBwcmVyZWdpc3RyYXRpb24gW2hlcmVdKGh0dHBzOi8vb3NmLmlvL2o3MmRnLykuIAoKYGBge3J9CiMgbG9hZCByZXF1aXJlZCBsaWJyYXJpZXMKbGlicmFyeSh0aWR5dmVyc2UpCmxpYnJhcnkobGFuZ2NvZykgIyBzb3VyY2U6IGh0dHBzOi8vZ2l0aHViLmNvbS9sYW5nY29nL2xhbmdjb2ctcGFja2FnZQpsaWJyYXJ5KHBzeWNoKQpsaWJyYXJ5KGxtZTQpCgojIHNldCB0aGVtZSBmb3IgZ2dwbG90cwp0aGVtZV9zZXQodGhlbWVfYncoKSkKCmNob3Nlbl9yb3QgPC0gIm9ibGltaW4iCmBgYAoKYGBge3J9CiMgcnVuIHNvdXJjZSBjb2RlIChleHRyYSBob21lLW1hZGUgZnVuY3Rpb25zKQpzb3VyY2UoIi4vc2NyaXB0cy9tYXhfZmFjdG9yc19lZmEuUiIpCnNvdXJjZSgiLi9zY3JpcHRzL3Bsb3RfZnVuLlIiKQpzb3VyY2UoIi4vc2NyaXB0cy9yZXRlbl9mdW4uUiIpCnNvdXJjZSgiLi9zY3JpcHRzL2RhdGFfcHJlcC5SIikKYGBgCgoKIyBTdHVkeSAxIEVGQQoKYGBge3J9CiMgbG9hZCBpbiBFRkEgcmVzdWx0cyBmcm9tIHN0dWR5IDEKZWZhX1MxIDwtIHJlYWRSRFMoIi4uL3N0dWR5IDEvczFfZWZhLnJkcyIpCmBgYAoKYGBge3IsIGZpZy53aWR0aCA9IDQsIGZpZy5hc3AgPSAxLjV9CmhlYXRtYXBfZnVuKGVmYV9TMSkgKyAKICBsYWJzKHRpdGxlID0gcGFzdGUwKCJTVFVEWSAxIFBhcmFsbGVsIEFuYWx5c2lzIChyb3RhdGlvbjogIiwgY2hvc2VuX3JvdCwgIikiKSwKICAgICAgIHN1YnRpdGxlID0gIiclIHZhci4nIGluZGljYXRlcyB0aGUgYW1vdW50IG9mIHNoYXJlZCB2YXJpYW5jZSBleHBsYWluZWQgKHRvdGFsID0gMTAwJSkiKQpgYGAKCiMgRUZBCgpUbyB0ZXN0IEgxLCB3ZSBwbGFubmVkIHRvIGNvbmR1Y3QgYW4gZXhwbG9yYXRvcnkgZmFjdG9yIGFuYWx5c2lzIChFRkEpIGNvbGxhcHNpbmcgYWNyb3NzIGFsbCAxMyB0YXJnZXQgY2hhcmFjdGVycyAoYW5kIHRyZWF0aW5nIGFuIGluZGl2aWR1YWwgcGFydGljaXBhbnQncyByZXNwb25zZXMgdG8gZWFjaCBjaGFyYWN0ZXIgYXMgaWYgdGhleSB3ZXJlIGluZGVwZW5kZW50IGRhdGEgcG9pbnRzKSAtIHNlZSB0aGUgcHJlcmVnaXN0cmF0aW9uIGZvciBtb3JlIGRldGFpbHMuICAKCkFzIHdpdGggU3R1ZHkgMSwgd2UgcGxhbm5lZCB0byBleGFtaW5lIHRocmVlIGZhY3RvciByZXRlbnRpb24gcHJvdG9jb2xzIGluIG9yZGVyIHRvIGRldGVybWluZSBob3cgbWFueSBmYWN0b3JzIHRvIHJldGFpbjogUGFyYWxsZWwgYW5hbHlzaXMsIG1pbmltaXppbmcgQklDLCBhbmQgYSBzZXQgb2YgcHJlc2V0IGNyaXRlcmlhIG91dGxpbmVkIGluIFdlaXNtYW4gZXQgYWwuICgyMDE3KS4gSGVyZSB3ZSBsb29rIGF0IGVhY2ggc29sdXRpb24gaW4gdHVybi4KCldlIHByZWRpY3RlZCB0aGF0IHdlJ2Qgc2VlIGEgc2ltaWxhciBmYWN0b3Igc3RydWN0dXJlIHRvIHRoYXQgZm91bmQgaW4gU3R1ZHkgMS4KCgojIyBSb3RhdGlvbiBjaG9pY2VzCgpXZSBwbGFubmVkIHRvIGV4YW1pbmUgb2JsaW1pbi1yb3RhdGVkIHNvbHV0aW9ucyAod2hpY2ggYWxsb3cgZmFjdG9ycyB0byBjb3JyZWxhdGUpLCBidXQgeW91IGNvdWxkIGV4YW1pbmUgb3RoZXIgcm90YXRpb24gb3B0aW9ucyBieSBzZWxlY3RpbmcgYSBkaWZmZXJlbnQgcm90YXRpb24gdHlwZSBoZXJlLgoKYGBge3J9CmNob3Nlbl9yb3QgPC0gIm9ibGltaW4iICMgcHJlcmVnaXN0ZXJlZDogZmFjdG9ycyBhbGxvd2VkIHRvIGNvcnJlbGF0ZQojIGNob3Nlbl9yb3QgPC0gInZhcmltYXgiICMgb3J0aG9nb25hbDogZmFjdG9ycyBmb3JjZWQgbm90IHRvIGNvcnJlbGF0ZQojIGNob3Nlbl9yb3QgPC0gIm5vbmUiICMgbm8gcm90YXRpb24KYGBgCgoKIyMgUGFyYWxsZWwgYW5hbHlzaXMKCiMjIyBIb3cgbWFueSBmYWN0b3JzIHRvIHJldGFpbj8KCmBgYHtyfQpyZXRlbl9hbGxfUEEgPC0gZmEucGFyYWxsZWwoZF9hbGwsIHBsb3QgPSBGKTsgcmV0ZW5fYWxsX1BBCnJldGVuX2FsbF9wYXIgPC0gcmV0ZW5fYWxsX1BBJG5mYWN0CmBgYAoKIyMjIFdoYXQgYXJlIHRoZXNlIGZhY3RvcnM/CgpgYGB7cn0KZWZhX2FsbF9wYXIgPC0gZmEoZF9hbGwsIG5mYWN0b3JzID0gcmV0ZW5fYWxsX3Bhciwgcm90YXRlID0gY2hvc2VuX3JvdCwKICAgICAgICAgICAgICAgICAgc2NvcmVzID0gInRlbkJlcmdlIiwgaW1wdXRlID0gIm1lZGlhbiIpCmBgYAoKYGBge3IsIGZpZy53aWR0aCA9IDQsIGZpZy5hc3AgPSAwLjd9CmhlYXRtYXBfZnVuKGVmYV9hbGxfcGFyKSArIAogIGxhYnModGl0bGUgPSBwYXN0ZTAoIlBhcmFsbGVsIEFuYWx5c2lzIChyb3RhdGlvbjogIiwgY2hvc2VuX3JvdCwgIikiKSwKICAgICAgIHN1YnRpdGxlID0gIiclIHZhci4nIGluZGljYXRlcyB0aGUgYW1vdW50IG9mIHNoYXJlZCB2YXJpYW5jZSBleHBsYWluZWQgKHRvdGFsID0gMTAwJSkiKQpgYGAKClRoZXNlIGZhY3RvcnMgbG9vayBleHRyZW1lbHkgc2ltaWxhciB0byB3aGF0IHdlIHNhdyBpbiBTdHVkeSAxIChzZWUgYWJvdmUpLiBJIChLYXJhKSB3b3VsZCBzYXkgdGhhdCBIMSBpcyBzdHJvbmdseSBzdXBwb3J0ZWQuCgoKIyMjIFdoaWNoIGNhcGFjaXRpZXMgYXJlIGF0dHJpYnV0ZWQgdG8gd2hpY2ggdGFyZ2V0cz8KCldlIGNvdWxkIGxvb2sgYXQgZmFjdG9yIHNjb3JlcyB1c2luZyB0aGUgU3R1ZHkgMiBFRkEgdG8gc2VlIHdoaWNoIGNhcGFjaXRpZXMgd2VyZSBhdHRyaWJ1dGVkIHRvIHdoaWNoIHRhcmdldHMuIFRoaXMgaXMgbm90IHRoZSBwcmltYXJ5IHdheSB3ZSBwbGFubmVkIHRvIGludmVzdGlnYXRlIHRoaXMgLSB0aGlzIHdhcyBsaXN0ZWQgYXMgYSAiZm9sbG93LXVwIGFuYWx5c2lzIiAtIGJ1dCBJJ20gcHV0dGluZyBpdCBoZXJlIHNvIHRoYXQgaXQncyBpbiBjbG9zZSBwcm94aW1pdHkgdG8gdGhlIEVGQSByZXN1bHRzIGZvciBlYXNlIG9mIGludGVycHJldGF0aW9uLgoKIyMjIyBBZ2UgYXMgbnVtZXJpYyAocmF3KQoKYGBge3IsIGZpZy53aWR0aCA9IDQsIGZpZy5hc3AgPSAwLjV9CnNjb3Jlc3Bsb3RfZnVuKGVmYV9hbGxfcGFyLCB0YXJnZXQgPSAiYWxsIChzdHVkeSAyKSIsIAogICAgICAgICAgICAgICB0YXJnZXRfZW5jb2RpbmcgPSAibnVtZXJpYyIpICsKICBzY2FsZV94X2NvbnRpbnVvdXMoYnJlYWtzID0gc2VxKDAsIDYwLCAxMikpICsKICBsYWJzKHRpdGxlID0gIlBhcmFsbGVsIEFuYWx5c2lzIikgKwogIHRoZW1lKGF4aXMudGV4dC54ID0gZWxlbWVudF90ZXh0KGFuZ2xlID0gNDUsIGhqdXN0ID0gMSwgdmp1c3QgPSAxKSkKYGBgCgojIyMjIEFnZSBhcyBudW1lcmljIChzcXVhcmUtcm9vdC10cmFuc2Zvcm1lZCkKCmBgYHtyLCBmaWcud2lkdGggPSA0LCBmaWcuYXNwID0gMC41fQpzY29yZXNwbG90X2Z1bihlZmFfYWxsX3BhciwgdGFyZ2V0ID0gImFsbCAoc3R1ZHkgMikiLCAKICAgICAgICAgICAgICAgdGFyZ2V0X2VuY29kaW5nID0gIm51bWVyaWMiKSArCiAgc2NhbGVfeF9jb250aW51b3VzKGJyZWFrcyA9IHNlcSgwLCA2MCwgMTIpLCB0cmFucyA9ICJzcXJ0IikgKwogIGxhYnModGl0bGUgPSAiUGFyYWxsZWwgQW5hbHlzaXMiLCAKICAgICAgIHggPSAiYWdlIGFmdGVyIHNxdWFyZS1yb290IHRyYW5zZm9ybWF0aW9uIChtb250aHMpIikgKwogIHRoZW1lKGF4aXMudGV4dC54ID0gZWxlbWVudF90ZXh0KGFuZ2xlID0gNDUsIGhqdXN0ID0gMSwgdmp1c3QgPSAxKSkKYGBgCgoKIyMjIyBBZ2UgYXMgb3JkaW5hbAoKYGBge3IsIGZpZy53aWR0aCA9IDQsIGZpZy5hc3AgPSAwLjV9CnNjb3Jlc3Bsb3RfZnVuKGVmYV9hbGxfcGFyLCB0YXJnZXQgPSAiYWxsIChzdHVkeSAyKSIsIAogICAgICAgICAgICAgICB0YXJnZXRfZW5jb2RpbmcgPSAib3JkaW5hbCIpICsKICBsYWJzKHRpdGxlID0gIlBhcmFsbGVsIEFuYWx5c2lzIiwgCiAgICAgICB4ID0gImFnZSAob3JkaW5hbCkiKSArCiAgdGhlbWUoYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoYW5nbGUgPSA0NSwgaGp1c3QgPSAxLCB2anVzdCA9IDEpKQpgYGAKCgpBbmQgaGVyZSdzIGEgY2xvc2UgbG9vayBhdCBhbGwgb2YgdGhlIHJhdyBkYXRhIChjb2xvci1jb2RlZCBhY2NvcmRpbmcgdG8gdGhlIFN0dWR5IDIgRUZBIHJlc3VsdHMpOgoKYGBge3IsIGZpZy53aWR0aCA9IDgsIGZpZy5hc3AgPSAwLjR9Cml0ZW1zcGxvdF9mdW4oZWZhX2FsbF9wYXIsIHRhcmdldCA9ICJhbGwgKHN0dWR5IDIpIikgKyAKICBsYWJzKHRpdGxlID0gIlBhcmFsbGVsIEFuYWx5c2lzIikKYGBgCgpgYGB7ciwgZmlnLndpZHRoID0gNiwgZmlnLmFzcCA9IDAuN30KZF9hbGwgJT4lCiAgcm93bmFtZXNfdG9fY29sdW1uKCJzdWJpZF90YXJnZXQiKSAlPiUKICBtdXRhdGUoc3ViaWQgPSBnc3ViKCJfLiokIiwgIiIsIHN1YmlkX3RhcmdldCksCiAgICAgICAgIHRhcmdldCA9IGdzdWIoIl4uKl8iLCAiIiwgc3ViaWRfdGFyZ2V0KSwKICAgICAgICAgdGFyZ2V0X251bSA9IHJlY29kZSh0YXJnZXQsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgInRhcmdldDAwbW8iID0gMCwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MFhtbyIgPSA0LzMwLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICJ0YXJnZXQwMW1vIiA9IDEsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgInRhcmdldDAybW8iID0gMiwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MDRtbyIgPSA0LAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICJ0YXJnZXQwNm1vIiA9IDYsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgInRhcmdldDA5bW8iID0gOSwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MTJtbyIgPSAxMiwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MThtbyIgPSAxOCwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MjRtbyIgPSAyNCwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MzZtbyIgPSAzNiwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0NDhtbyIgPSA0OCwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0NjBtbyIgPSA2MCksCiAgICAgICAgIHRhcmdldF9vcmQgPSByZWNvZGVfZmFjdG9yKHRhcmdldCwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgInRhcmdldDAwbW8iID0gIm5ld2Jvcm5zIiwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgInRhcmdldDBYbW8iID0gIjQtZGF5LW9sZHMiLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MDFtbyIgPSAiMS1tb250aC1vbGRzIiwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgInRhcmdldDAybW8iID0gIjItbW9udGgtb2xkcyIsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICJ0YXJnZXQwNG1vIiA9ICI0LW1vbnRoLW9sZHMiLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MDZtbyIgPSAiNi1tb250aC1vbGRzIiwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgInRhcmdldDA5bW8iID0gIjktbW9udGgtb2xkcyIsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICJ0YXJnZXQxMm1vIiA9ICIxMi1tb250aC1vbGRzIiwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgInRhcmdldDE4bW8iID0gIjE4LW1vbnRoLW9sZHMiLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MjRtbyIgPSAiMi15ZWFyLW9sZHMiLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MzZtbyIgPSAiMy15ZWFyLW9sZHMiLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0NDhtbyIgPSAiNC15ZWFyLW9sZHMiLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0NjBtbyIgPSAiNS15ZWFyLW9sZHMiKSkgJT4lCiAgc2VsZWN0KC1jKHN1YmlkX3RhcmdldCwgdGFyZ2V0KSkgJT4lCiAgZ2F0aGVyKGNhcGFjaXR5LCByZXNwb25zZSwgLWMoc3ViaWQsIHN0YXJ0c193aXRoKCJ0YXJnZXQiKSkpICU+JQogIGZ1bGxfam9pbihlZmFfYWxsX3BhciRsb2FkaW5nc1tdICU+JQogICAgICAgICAgICAgIGRhdGEuZnJhbWUoKSAlPiUKICAgICAgICAgICAgICByb3duYW1lc190b19jb2x1bW4oImNhcGFjaXR5IikgJT4lCiAgICAgICAgICAgICAgZ2F0aGVyKGZhY3RvciwgbG9hZGluZywgLWNhcGFjaXR5KSAlPiUKICAgICAgICAgICAgICBncm91cF9ieShjYXBhY2l0eSkgJT4lCiAgICAgICAgICAgICAgdG9wX24oMSwgYWJzKGxvYWRpbmcpKSAlPiUKICAgICAgICAgICAgICB1bmdyb3VwKCkgJT4lCiAgICAgICAgICAgICAgYXJyYW5nZShmYWN0b3IsIGRlc2MoYWJzKGxvYWRpbmcpKSkgJT4lCiAgICAgICAgICAgICAgbXV0YXRlKG9yZGVyID0gMToyMCkgJT4lCiAgICAgICAgICAgICAgc2VsZWN0KGNhcGFjaXR5LCBmYWN0b3IsIG9yZGVyKSkgJT4lCiAgIyBnZ3Bsb3QoYWVzKHggPSB0YXJnZXRfb3JkLCB5ID0gcmVzcG9uc2UsIGNvbG9yID0gZmFjdG9yKSkgKwogIGdncGxvdChhZXMoeCA9IHRhcmdldF9udW0sIHkgPSByZXNwb25zZSwgY29sb3IgPSBmYWN0b3IpKSArCiAgZmFjZXRfd3JhcCh+IHJlb3JkZXIoY2FwYWNpdHksIG9yZGVyKSkgKwogIGdlb21fbGluZShhZXMoZ3JvdXAgPSBzdWJpZCksIGFscGhhID0gMC4xKSArCiAgZ2VvbV9zbW9vdGgoYWVzKGdyb3VwID0gY2FwYWNpdHkpLAogICAgICAgICAgICAgIG1ldGhvZCA9ICJsbSIsIGZvcm11bGEgPSAieSB+IHBvbHkoeCwgMykiLAogICAgICAgICAgICAgIGNvbG9yID0gImJsYWNrIikgKwogIHNjYWxlX2NvbG9yX2JyZXdlcihwYWxldHRlID0gIlNldDIiLCBndWlkZSA9ICJub25lIikgKwogICMgc2NhbGVfeF9kaXNjcmV0ZSgidGFyZ2V0IGFnZSAob3JkaW5hbCkiKSArCiAgc2NhbGVfeF9jb250aW51b3VzKCJ0YXJnZXQgYWdlIChtb250aHMpIiwgYnJlYWtzID0gc2VxKDAsIDYwLCAxMikpICsKICAjIHNjYWxlX3hfY29udGludW91cygiYWdlIGFmdGVyIHNxdWFyZS1yb290IHRyYW5zZm9ybWF0aW9uIChtb250aHMpIiwgCiAgIyAgICAgICAgICAgICAgICAgICAgYnJlYWtzID0gc2VxKDAsIDYwLCAxMiksIHRyYW5zID0gInNxcnQiKSArCiAgdGhlbWUoYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoYW5nbGUgPSA0NSwgaGp1c3QgPSAxLCB2anVzdCA9IDEpKSArCiAgZ3VpZGVzKGNvbG9yID0gZ3VpZGVfbGVnZW5kKG92ZXJyaWRlLmFlcyA9IGxpc3QoYWxwaGEgPSAxKSkpCmBgYAoKCiMjIE1pbmltaXppbmcgQklDCgojIyMgSG93IG1hbnkgZmFjdG9ycyB0byByZXRhaW4/CgpgYGB7cn0KcmV0ZW5fYWxsX3ZzcyA8LSBWU1MoZF9hbGwsIHBsb3QgPSBGKTsgcmV0ZW5fYWxsX3ZzcwpyZXRlbl9hbGxfYmljIDwtIGRhdGEuZnJhbWUocmV0ZW5fYWxsX3ZzcyR2c3Muc3RhdHMgJT4lCiAgcm93bmFtZXNfdG9fY29sdW1uKCJuZmFjdG9ycyIpICU+JQogIHRvcF9uKC0xLCBCSUMpICU+JQogIHNlbGVjdChuZmFjdG9ycykpJG5mYWN0b3JzICU+JSBhcy5udW1lcmljKCkKYGBgCgojIyMgV2hhdCBhcmUgdGhlc2UgZmFjdG9ycz8KCmBgYHtyfQplZmFfYWxsX2JpYyA8LSBmYShkX2FsbCwgbmZhY3RvcnMgPSByZXRlbl9hbGxfYmljLCByb3RhdGUgPSBjaG9zZW5fcm90LAogICAgICAgICAgICAgICAgICBzY29yZXMgPSAidGVuQmVyZ2UiLCBpbXB1dGUgPSAibWVkaWFuIikKYGBgCgpgYGB7ciwgZmlnLndpZHRoID0gNCwgZmlnLmFzcCA9IDAuN30KaGVhdG1hcF9mdW4oZWZhX2FsbF9iaWMpICsgCiAgbGFicyh0aXRsZSA9IHBhc3RlMCgiTWluaW1pemluZyBCSUMgKHJvdGF0aW9uOiAiLCBjaG9zZW5fcm90LCAiKSIpLAogICAgICAgc3VidGl0bGUgPSAiJyUgdmFyLicgaW5kaWNhdGVzIHRoZSBhbW91bnQgb2Ygc2hhcmVkIHZhcmlhbmNlIGV4cGxhaW5lZCAodG90YWwgPSAxMDAlKSIpCmBgYAoKQSBtb3JlIGNvbXBsZXggcGljdHVyZSwgYnV0IHRoZSBmaXJzdCA0IGZhY3RvcnMgbG9vayBzaW1pbGFyIHRvIHdoYXQgd2UgZ2V0IHRocm91Z2ggcGFyYWxsZWwgYW5hbHlzaXMuIChJIHRoaW5rIHNvbWV0aGluZyBzaW1pbGFyIGhhcHBlbmVkIHdpdGggU3R1ZHkgMSwgYnV0IHdlIHNob3VsZCBnbyBiYWNrIGFuZCBjb21wYXJlLikKCiMjIyBXaGljaCBjYXBhY2l0aWVzIGFyZSBhdHRyaWJ1dGVkIHRvIHdoaWNoIHRhcmdldHM/CgpgYGB7ciwgZmlnLndpZHRoID0gNCwgZmlnLmFzcCA9IDAuN30Kc2NvcmVzcGxvdF9mdW4oZWZhX2FsbF9iaWMsIHRhcmdldCA9ICJhbGwgKHN0dWR5IDIpIikgKyAKICBsYWJzKHRpdGxlID0gIk1pbmltaXppbmcgQklDIikgKwogIHRoZW1lKGF4aXMudGV4dC54ID0gZWxlbWVudF90ZXh0KGFuZ2xlID0gNDUsIGhqdXN0ID0gMSwgdmp1c3QgPSAxKSkKYGBgCgpXZSdsbCBza2lwIHJlZ3Jlc3Npb24gYW5hbHlzZXMgYW5kIG90aGVyIHBsb3RzIGZvciBub3cuCgoKIyMgUHJlc2V0IHJldGVudGlvbiBjcml0ZXJpYQoKIyMjIEhvdyBtYW55IGZhY3RvcnMgdG8gcmV0YWluPwoKYGBge3J9CnJldGVuX2FsbF9rIDwtIHJldGVuX2Z1bihkX2FsbCwgcm90X3R5cGUgPSBjaG9zZW5fcm90KQpwcmludChwYXN0ZSgiUHJlc2V0IGNyaXRlcmlhIHN1Z2dlc3QgcmV0YWluaW5nIiwgcmV0ZW5fYWxsX2ssICJmYWN0b3JzIikpCmBgYAoKVGhpcyBnaXZlcyB0aGUgc2FtZSBzb2x1dGlvbiBhcyBwYXJhbGxlbCBhbmFseXNpcyAtIDQgZmFjdG9ycyA6KQoKCiMgUHJvamVjdGluZyBpbnRvIFN0dWR5IDEgZmFjdG9yIHNwYWNlCgoqKkkgKEthcmEpIG1hZGUgYSBiaWcgbWlzdGFrZSBpbiB0aGlua2luZyB0aHJvdWdoIHRoaXM6IEkgdGhvdWdodCB3ZSBjb3VsZCBwcm9qZWN0IGEgMjAtdmFyaWFibGUgZGF0YXNldCBpbnRvIGEgNjAtdmFyaWFibGUgZGF0YXNldCB1c2luZyB0aGUgYHByZWRpY3QucHN5Y2goKWAgZnVuY3Rpb24sIGJ1dCB3ZSBjYW4ndCEqKgoKSSd2ZSB0cmllZCB0byBoYWNrIHRvZ2V0aGVyIGEgd2F5IHRvIGRvIHRoaXMsIGJ5IHJlcGxhY2luZyBhbGwgbWlzc2luZyB2YWx1ZXMgYXQgcmFuZG9tIChlaXRoZXIgd2l0aGluIHRoZSBmdWxsIHJhbmdlIG9mIHRoZSBzY2FsZSwgb3IgYXJvdW5kIHRoZSBtaWRwb2ludCwgb3IgbmVhciAwKSAtIGJ1dCBJIGhhdmVuJ3QgZ290dGVuIGFueXRoaW5nIHRvIHdvcmsuIEFzIHlvdSBjYW4gc2VlIGJlbG93IChyZXBsYWNpbmcgbWlzc2luZyB2YWx1ZXMgYXQgcmFuZG9tIGJldHdlZW4gMC01KSwgeW91IHNlZSBzbGlnaHQgaW5jcmVhc2VzIGFjcm9zcyBhbGwgZmFjdG9ycywgYW5kIHRoZSBtb3N0IGRyYW1hdGljIGluY3JlYXNlIGZvciBGYWN0b3IgNCAtIGJ1dCBJIHRoaW5rIHRoaXMgaXMgYmVjYXVzZSB0aGF0IGZhY3RvciBpcyBsZWFzdCB3ZWxsLWRlZmluZWQgaW4gdGhlIFN0dWR5IDEgRUZBIHNvbHV0aW9uPyAgSSB0aGluayB3ZSBuZWVkIHRvIGZvY3VzIG9uIGFuYWx5emluZyBmYWN0b3Igc2NvcmVzIGZyb20gb3VyIFN0dWR5IDIgRUZBLiBJJ20gc29ycnkgZm9yIHRoaXMgbWlzdGFrZSEKCmBgYHtyfQpleHRyYV92YXIgPC0gcm93bmFtZXMoZWZhX1MxJGxvYWRpbmdzKVshcm93bmFtZXMoZWZhX1MxJGxvYWRpbmdzKSAlaW4lIHJvd25hbWVzKGVmYV9hbGxfcGFyJGxvYWRpbmdzKV0KCnRlbXAgPC0gZF9hbGwgJT4lCiAgcm93bmFtZXNfdG9fY29sdW1uKCJzdWJpZCIpICU+JQogIG11dGF0ZShiZWluZ19hZnJhaWRfb2Zfc29tZWJvZHkgPSByb3VuZChydW5pZigzMDgxLCAwLCA1KSksIAogICAgICAgICBiZWluZ19hbmdyeV9hdF9zb21lYm9keSA9IHJvdW5kKHJ1bmlmKDMwODEsIDAsIDUpKSwKICAgICAgICAgYmVpbmdfYXdhcmVfb2ZfdGhpbmdzID0gcm91bmQocnVuaWYoMzA4MSwgMCwgNSkpLCAKICAgICAgICAgYmVpbmdfY29tZm9ydGVkX2J5X3BoeXNpY2FsX3RvdWNoID0gcm91bmQocnVuaWYoMzA4MSwgMCwgNSkpLAogICAgICAgICBjYWxtaW5nX3RoZW1zZWx2ZXNfZG93biA9IHJvdW5kKHJ1bmlmKDMwODEsIDAsIDUpKSwgCiAgICAgICAgIGRldGVjdGluZ19kYW5nZXIgPSByb3VuZChydW5pZigzMDgxLCAwLCA1KSksIAogICAgICAgICBmZWVsaW5nX2Fubm95ZWQgPSByb3VuZChydW5pZigzMDgxLCAwLCA1KSksIAogICAgICAgICBmZWVsaW5nX2JvcmVkID0gcm91bmQocnVuaWYoMzA4MSwgMCwgNSkpLCAKICAgICAgICAgZmVlbGluZ19jYWxtID0gcm91bmQocnVuaWYoMzA4MSwgMCwgNSkpLAogICAgICAgICBmZWVsaW5nX2NvbmZ1c2VkID0gcm91bmQocnVuaWYoMzA4MSwgMCwgNSkpLCAKICAgICAgICAgZmVlbGluZ19lbWJhcnJhc3NlZCA9IHJvdW5kKHJ1bmlmKDMwODEsIDAsIDUpKSwgCiAgICAgICAgIGZlZWxpbmdfZ3VpbHR5ID0gcm91bmQocnVuaWYoMzA4MSwgMCwgNSkpLAogICAgICAgICBmZWVsaW5nX2hvcGVsZXNzID0gcm91bmQocnVuaWYoMzA4MSwgMCwgNSkpLCAKICAgICAgICAgZmVlbGluZ19sb3ZlZCA9IHJvdW5kKHJ1bmlmKDMwODEsIDAsIDUpKSwgCiAgICAgICAgIGZlZWxpbmdfbmVnbGVjdGVkID0gcm91bmQocnVuaWYoMzA4MSwgMCwgNSkpLAogICAgICAgICBmZWVsaW5nX3BsZWFzdXJlID0gcm91bmQocnVuaWYoMzA4MSwgMCwgNSkpLCAKICAgICAgICAgZmVlbGluZ19wcmlkZSA9IHJvdW5kKHJ1bmlmKDMwODEsIDAsIDUpKSwgCiAgICAgICAgIGZlZWxpbmdfc2FkID0gcm91bmQocnVuaWYoMzA4MSwgMCwgNSkpLAogICAgICAgICBmZWVsaW5nX3NhZmUgPSByb3VuZChydW5pZigzMDgxLCAwLCA1KSksIAogICAgICAgICBmZWVsaW5nX3NjYXJlZCA9IHJvdW5kKHJ1bmlmKDMwODEsIDAsIDUpKSwgCiAgICAgICAgIGZlZWxpbmdfdGV4dHVyZXMgPSByb3VuZChydW5pZigzMDgxLCAwLCA1KSksCiAgICAgICAgIGZlZWxpbmdfdGhpcnN0eSA9IHJvdW5kKHJ1bmlmKDMwODEsIDAsIDUpKSwgCiAgICAgICAgIGZlZWxpbmdfdG9vX2hvdF9vcl90b29fY29sZCA9IHJvdW5kKHJ1bmlmKDMwODEsIDAsIDUpKSwKICAgICAgICAgZmVlbGluZ193b3JyaWVkID0gcm91bmQocnVuaWYoMzA4MSwgMCwgNSkpLCAKICAgICAgICAgZm9jdXNpbmdfb25fYV9nb2FsID0gcm91bmQocnVuaWYoMzA4MSwgMCwgNSkpLCAKICAgICAgICAgZ2V0dGluZ19hbmdyeSA9IHJvdW5kKHJ1bmlmKDMwODEsIDAsIDUpKSwKICAgICAgICAgZ2V0dGluZ19odXJ0X2ZlZWxpbmdzID0gcm91bmQocnVuaWYoMzA4MSwgMCwgNSkpLCAKICAgICAgICAgZ2V0dGluZ19wbGVhc3VyZV9mcm9tX211c2ljID0gcm91bmQocnVuaWYoMzA4MSwgMCwgNSkpLAogICAgICAgICBoYXZpbmdfZ29hbHMgPSByb3VuZChydW5pZigzMDgxLCAwLCA1KSksIAogICAgICAgICBoYXZpbmdfdGhvdWdodHMgPSByb3VuZChydW5pZigzMDgxLCAwLCA1KSksIAogICAgICAgICBoYXZpbmdfd2FudHNfYW5kX2Rlc2lyZXMgPSByb3VuZChydW5pZigzMDgxLCAwLCA1KSksCiAgICAgICAgIGltYWdpbmluZ190aGluZ3MgPSByb3VuZChydW5pZigzMDgxLCAwLCA1KSksIAogICAgICAgICBsaXN0ZW5pbmdfdG9fc29tZWJvZHkgPSByb3VuZChydW5pZigzMDgxLCAwLCA1KSksIAogICAgICAgICBtYWtpbmdfY2hvaWNlcyA9IHJvdW5kKHJ1bmlmKDMwODEsIDAsIDUpKSwKICAgICAgICAgcmVjb2duaXppbmdfb3RoZXJzX2Vtb3Rpb25zID0gcm91bmQocnVuaWYoMzA4MSwgMCwgNSkpLCAKICAgICAgICAgcmVjb2duaXppbmdfc29tZWJvZHlfZWxzZSA9IHJvdW5kKHJ1bmlmKDMwODEsIDAsIDUpKSwKICAgICAgICAgcmVtZW1iZXJpbmdfdGhpbmdzID0gcm91bmQocnVuaWYoMzA4MSwgMCwgNSkpLCAKICAgICAgICAgc2VlaW5nID0gcm91bmQocnVuaWYoMzA4MSwgMCwgNSkpLCAKICAgICAgICAgdGhpbmtpbmdfYmVmb3JlX3RoZXlfYWN0ID0gcm91bmQocnVuaWYoMzA4MSwgMCwgNSkpLAogICAgICAgICB1bmRlcnN0YW5kaW5nX3doYXRfc29tZWJvZHlfZWxzZV9pc190aGlua2luZyA9IHJvdW5kKHJ1bmlmKDMwODEsIDAsIDUpKSkgJT4lCiAgY29sdW1uX3RvX3Jvd25hbWVzKCJzdWJpZCIpCgpzY29yZXNfcHJvamVjdCA8LSBwcmVkaWN0LnBzeWNoKG9iamVjdCA9IGVmYV9TMSwgZGF0YSA9IHRlbXApCmBgYAoKYGBge3IsIGZpZy53aWR0aCA9IDQsIGZpZy5hc3AgPSAwLjd9CnNjb3Jlc19wcm9qZWN0ICU+JQogIGRhdGEuZnJhbWUoKSAlPiUKICByb3duYW1lc190b19jb2x1bW4oInN1YmlkX3RhcmdldCIpICU+JQogIG11dGF0ZShzdWJpZCA9IGdzdWIoIl8uKiQiLCAiIiwgc3ViaWRfdGFyZ2V0KSwKICAgICAgICAgdGFyZ2V0ID0gZ3N1YigiXi4qXyIsICIiLCBzdWJpZF90YXJnZXQpLAogICAgICAgICB0YXJnZXRfbnVtID0gcmVjb2RlKHRhcmdldCwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MDBtbyIgPSAwLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICJ0YXJnZXQwWG1vIiA9IHJvdW5kKDQvMzAsIDMpLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICJ0YXJnZXQwMW1vIiA9IDEsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgInRhcmdldDAybW8iID0gMiwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MDRtbyIgPSA0LAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICJ0YXJnZXQwNm1vIiA9IDYsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgInRhcmdldDA5bW8iID0gOSwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MTJtbyIgPSAxMiwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MThtbyIgPSAxOCwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MjRtbyIgPSAyNCwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MzZtbyIgPSAzNiwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0NDhtbyIgPSA0OCwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0NjBtbyIgPSA2MCksCiAgICAgICAgIHRhcmdldF9vcmQgPSByZWNvZGVfZmFjdG9yKHRhcmdldCwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgInRhcmdldDAwbW8iID0gIm5ld2Jvcm5zIiwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgInRhcmdldDBYbW8iID0gIjQtZGF5LW9sZHMiLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MDFtbyIgPSAiMS1tb250aC1vbGRzIiwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgInRhcmdldDAybW8iID0gIjItbW9udGgtb2xkcyIsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICJ0YXJnZXQwNG1vIiA9ICI0LW1vbnRoLW9sZHMiLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MDZtbyIgPSAiNi1tb250aC1vbGRzIiwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgInRhcmdldDA5bW8iID0gIjktbW9udGgtb2xkcyIsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICJ0YXJnZXQxMm1vIiA9ICIxMi1tb250aC1vbGRzIiwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgInRhcmdldDE4bW8iID0gIjE4LW1vbnRoLW9sZHMiLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MjRtbyIgPSAiMi15ZWFyLW9sZHMiLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MzZtbyIgPSAiMy15ZWFyLW9sZHMiLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0NDhtbyIgPSAiNC15ZWFyLW9sZHMiLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0NjBtbyIgPSAiNS15ZWFyLW9sZHMiKSkgJT4lCiAgc2VsZWN0KC1zdWJpZF90YXJnZXQpICU+JQogIGdhdGhlcihmYWN0b3IsIHNjb3JlLCAtYyhzdWJpZCwgc3RhcnRzX3dpdGgoInRhcmdldCIpKSkgJT4lCiAgZ2dwbG90KGFlcyh4ID0gdGFyZ2V0X251bSwgeSA9IHNjb3JlLCBjb2xvciA9IGZhY3RvcikpICsKICBmYWNldF9ncmlkKH4gZmFjdG9yKSArCiAgZ2VvbV9saW5lKGFlcyhncm91cCA9IHN1YmlkKSwgYWxwaGEgPSAwLjEpICsKICBzY2FsZV94X2NvbnRpbnVvdXMoYnJlYWtzID0gc2VxKDAsIDYwLCAxMikpICsKICB0aGVtZShheGlzLnRleHQueCA9IGVsZW1lbnRfdGV4dChhbmdsZSA9IDQ1LCBoanVzdCA9IDEsIHZqdXN0ID0gMSksCiAgICAgICAgbGVnZW5kLnBvc2l0aW9uID0gIm5vbmUiKSArCiAgbGFicyh0aXRsZSA9ICJLYXJhJ3MgYXR0ZW1wdCB0byBwcm9qZWN0IGludG8gdGhlIFN0dWR5IDEgc3BhY2UiLAogICAgICAgc3VidGl0bGUgPSAiUmVwbGFjZWQgYWxsIG1pc3NpbmcgdmFsdWVzICg0MCBwZXIgcGFydGljaXBhbnQpIHdpdGggYSByYW5kb20gaW50ZWdlciBiZXR3ZWVuIDAtNSIsCiAgICAgICB4ID0gInRhcmdldCBhZ2UgKG1vbnRocykiLCB5ID0gImZhY3RvciBzY29yZSIpCmBgYAoKCgojIFJlZ3Jlc3Npb24gbW9kZWxzIGluIFN0dWR5IDIgZmFjdG9yIHNwYWNlCgpIZXJlJ3MgYSBtdWx0aWxldmVsIGxpbmVhciByZWdyZXNzaW9uIG9uIHRoZXNlIGZhY3RvciBzY29yZXMsIHdpdGggcmFuZG9tIGludGVyY2VwdHMgYW5kIHNsb3BlcyAoZm9yIHRhcmdldCBhbmQgZmFjdG9yKSBieSBwYXJ0aWNpcGFudC4gVGFyZ2V0IGlzIGNvZGVkIGFzIG51bWVyaWMsIHdpdGggb25seSB0aGUgbGluZWFyIGNvbnRyYXN0LgoKYGBge3J9CmVmYV9hbGxfcGFyX3Njb3JlcyA8LSBlZmFfYWxsX3BhciRzY29yZXNbXSAlPiUKICBkYXRhLmZyYW1lKCkgJT4lCiAgcm93bmFtZXNfdG9fY29sdW1uKCJzdWJpZCIpICU+JQogIG11dGF0ZSh0YXJnZXQgPSBnc3ViKCJeLipfdGFyZ2V0IiwgInRhcmdldCIsIHN1YmlkKSwKICAgICAgICAgUmVzcG9uc2VJZCA9IGdzdWIoIl90YXJnZXQuKiQiLCAiIiwgc3ViaWQpLAogICAgICAgICB0YXJnZXRfbnVtID0gcmVjb2RlKHRhcmdldCwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MDBtbyIgPSAwLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICJ0YXJnZXQwWG1vIiA9IHJvdW5kKDQvMzAsIDMpLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICJ0YXJnZXQwMW1vIiA9IDEsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgInRhcmdldDAybW8iID0gMiwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MDRtbyIgPSA0LAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICJ0YXJnZXQwNm1vIiA9IDYsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgInRhcmdldDA5bW8iID0gOSwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MTJtbyIgPSAxMiwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MThtbyIgPSAxOCwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MjRtbyIgPSAyNCwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MzZtbyIgPSAzNiwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0NDhtbyIgPSA0OCwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0NjBtbyIgPSA2MCksCiAgICAgICAgIHRhcmdldF9vcmQgPSByZWNvZGVfZmFjdG9yKHRhcmdldCwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgInRhcmdldDAwbW8iID0gIm5ld2Jvcm5zIiwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgInRhcmdldDBYbW8iID0gIjQtZGF5LW9sZHMiLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MDFtbyIgPSAiMS1tb250aC1vbGRzIiwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgInRhcmdldDAybW8iID0gIjItbW9udGgtb2xkcyIsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICJ0YXJnZXQwNG1vIiA9ICI0LW1vbnRoLW9sZHMiLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MDZtbyIgPSAiNi1tb250aC1vbGRzIiwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgInRhcmdldDA5bW8iID0gIjktbW9udGgtb2xkcyIsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICJ0YXJnZXQxMm1vIiA9ICIxMi1tb250aC1vbGRzIiwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgInRhcmdldDE4bW8iID0gIjE4LW1vbnRoLW9sZHMiLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MjRtbyIgPSAiMi15ZWFyLW9sZHMiLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0MzZtbyIgPSAiMy15ZWFyLW9sZHMiLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0NDhtbyIgPSAiNC15ZWFyLW9sZHMiLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAidGFyZ2V0NjBtbyIgPSAiNS15ZWFyLW9sZHMiKSkgJT4lCiAgc2VsZWN0KC1zdWJpZCwgLXRhcmdldCkgJT4lCiAgZ2F0aGVyKGZhY3Rvciwgc2NvcmUsIC1zdGFydHNfd2l0aCgidGFyZ2V0IiksIC1SZXNwb25zZUlkKSAlPiUKICBtdXRhdGVfYXQodmFycyhmYWN0b3IpLCBmdW5zKGZhY3RvcikpCgpjb250cmFzdHMoZWZhX2FsbF9wYXJfc2NvcmVzJGZhY3RvcikgPC0gY29udHIuc3VtKHJldGVuX2FsbF9wYXIpCgojIHJfYWxsX3BhciA8LSBsbWVyKHNjb3JlIH4gdGFyZ2V0X251bSAqIGZhY3RvcgojICAgICAgICAgICAgICAgICAgICsgKHRhcmdldF9udW0gKyBmYWN0b3IgfCBSZXNwb25zZUlkKSwKIyAgICAgICAgICAgICAgICAgICBlZmFfYWxsX3Bhcl9zY29yZXMpCiMgc3VtbWFyeShyX2FsbF9wYXIsIGNvcnIgPSBGKQpgYGAKCklmIHdlIHRyeSB0byBydW4gdGhlIG1vZGVsIGFib3ZlIChvdXIgcGxhbm5lZCBhbmFseXNpcyksIHdlIGdldCBhbiBlcnJvcjogIk1vZGVsIGlzIG5lYXJseSB1bmlkZW50aWZpYWJsZTogdmVyeSBsYXJnZSBlaWdlbnZhbHVlLiIgVGhlIGVycm9yIHN1Z2dlc3RzIHJlc2NhbGluZyB2YXJpYWJsZXMsIHdoaWNoIHNvbHZlcyB0aGUgcHJvYmxlbS4gSGVyZSBJJ3ZlIHJlLXNjYWxlZCBieSBkaXZpZGVkIGFnZSBpbiBtb250aHMgYnkgMTIsIHRvIGdldCBhZ2UgaW4geWVhcnMuICoqTGV0J3MgbWFrZSBzdXJlIHRvIHRhbGsgYWJvdXQgdGhpcy4qKgoKYGBge3J9CnJfYWxsX3Bhcl9yZXNjYWxlZCA8LSBsbWVyKHNjb3JlIH4gdGFyZ2V0X251bSAqIGZhY3RvcgogICAgICAgICAgICAgICAgICAgICAgICAgICArICh0YXJnZXRfbnVtICsgZmFjdG9yIHwgUmVzcG9uc2VJZCksCiAgICAgICAgICAgICAgICAgICAgICAgICAgIGVmYV9hbGxfcGFyX3Njb3JlcyAlPiUKICAgICAgICAgICAgICAgICAgICAgICAgICAgICBtdXRhdGUodGFyZ2V0X251bSA9IHRhcmdldF9udW0vMTIpKQpzdW1tYXJ5KHJfYWxsX3Bhcl9yZXNjYWxlZCwgY29yciA9IEYpCmBgYAoKQXMgd2UgcHJlZGljdGVkIChIMiksIHdlIHNlZSBkcmFtYXRpYyBpbmNyZWFzZXMgaW4gbWVudGFsIGNhcGFjaXR5IGF0dHJpYnV0aW9ucyBhY3Jvc3MgdGhlIGFnZSByYW5nZSAobWFpbiBlZmZlY3Qgb2YgYHRhcmdldF9udW1gKS4KCkFuZCBhbHNvIGFzIHdlIHByZWRpY3RlZCAoSDEpLCB3ZSBzZWUgZGlmZmVyZW5jZXMgYWNyb3NzIGZhY3RvcnMgaW4gd2hlcmUgbmV3Ym9ybnMgYXJlIHBlcmNlaXZlZCB0byBzdGFydCBvZmY6IFJlbGF0aXZlIHRvIHRoZSBncmFuZCBtZWFuLCBuZXdib3JucyBhcmUgcGVyY2VpdmVkIHRvIHN0YXJ0IG9mZiB3aXRoIG1vcmUgIm5lZ2F0aXZlIGVtb3Rpb25zIiAoZGlzdHJlc3MsIGZydXN0cmF0aW9uLCBldGMuOyBtYWluIGVmZmVjdCBvZiBgZmFjdG9yMWApLCBsZXNzL2Zld2VyIGNhcGFjaXRpZXMgaW4gdGhlIGRvbWFpbiBvZiAiY29nbml0aW9uIGFuZCBjb250cm9sIiAoZW1vdGlvbmFsIGNvbnRyb2wsIHNlbGYgY29udHJvbCwgZXRjLjsgbWFpbiBlZmZlY3Qgb2YgYGZhY3RvcjJgKSwgYW5kIHJlbGF0aXZlbHkgbW9yZSAiYm9kaWx5IHNlbnNhdGlvbnMiIChwYWluLCBmYXRpZ3VlLCBldGMuOyBtYWluIGVmZmVjdCBvZiBgZmFjdG9yM2ApLiAoV2UgY291bGQgcmVjb2RlIHRoaXMgdG8gbG9vayBhdCBgZmFjdG9yNGAsIG9yIGp1c3QgZXllYmFsbCBpdCBmcm9tIHRoZSBwbG90LikgQWxzbyBhcyBwcmVkaWN0ZWQsIHdlIHNlZSB0aGF0IHRoZSBwZXJjZWl2ZWQgY2hhbmdlcyBhY3Jvc3MgYWdlIHZhcnkgZHJhbWF0aWNhbGx5IGFjcm9zcyBmYWN0b3JzOiAibmVnYXRpdmUgZW1vdGlvbnMiIGFyZSBwZXJjZWl2ZWQgdG8gY2hhbmdlIHJlbGF0aXZlbHkgbGVzcyBvdmVyIGRldmVsb3BtZW50LCAiY29nbml0aW9uIGFuZCBjb250cm9sIiBhcmUgcGVyY2VpdmVkIHRvIGNoYW5nZSBtdWNoIG1vcmUgb3ZlciBkZXZlbG9wbWVudCwgYW5kICJib2RpbHkgc2Vuc2F0aW9ucyIgYXJlIHByZWRpY3RlZCB0byBjaGFnbmUgcmVsYXRpdmVseSBsZXNzLgoKVGhpcyBpcyBhbGwgdmVyeSBtdWNoIGluIGxpbmUgd2l0aCBvdXIgcHJlcmVnaXN0ZXJlZCBoeXBvdGhlc2VzIDopCgpOb3cgbGV0J3Mgc2VlIHdoYXQgdGhlIHBvbHlub21pYWwgZWZmZWN0cyBsb29rIGxpa2UgKGFnYWluLCBsb29raW5nIGF0IGFnZSBpbiB5ZWFycyBpbnN0ZWFkIG9mIG1vbnRocykuIEFzIHdlIGV4cGVjdGVkLCBpbmNsdWRpbmcgYWxsIG9mIHRoZSBwb2x5bm9taWFsIGVmZmVjdHMgYXMgcmFuZG9tIHNsb3BlcyBjYXVzZWQgdGhlIG1vZGVsIG5vdCB0byBjb252ZXJnZSAoSSB0aGluayB3ZSBtdXN0IGJlIGNhbGN1bGF0aW5nIGRmIHdyb25nKSwgc28gSSBpbXBsZW1lbnRlZCBvdXIgcHJlcmVnaXN0ZXJlZCByZW1lZHkgYW5kIGluY2x1ZGVkIG9ubHkgdGhlIGxpbmVhciBlZmZlY3QgYXMgYSByYW5kb20gc2xvcGUuCgpgYGB7cn0KIyBhZGRpbmcgcG9seW5vbWlhbCBlZmZlY3RzCnJfYWxsX3Bhcl9wb2x5IDwtIGxtZXIoc2NvcmUgfiBwb2x5KHRhcmdldF9udW0sIDMpICogZmFjdG9yCiAgICAgICAgICAgICAgICAgICAgICAgKyAocG9seSh0YXJnZXRfbnVtLCAxKSArIGZhY3RvciB8IFJlc3BvbnNlSWQpLAogICAgICAgICAgICAgICAgICAgICAgIGVmYV9hbGxfcGFyX3Njb3JlcyAlPiUKICAgICAgICAgICAgICAgICAgICAgICAgIG11dGF0ZSh0YXJnZXRfbnVtID0gdGFyZ2V0X251bS8xMikpCnN1bW1hcnkocl9hbGxfcGFyX3BvbHksIGNvcnIgPSBGKQpgYGAKCkxvdHMgdG8gc2lmdCB0aHJvdWdoIGhlcmUsIGJ1dCBpbiBnZW5lcmFsIHdlIHNlZSB0aGF0IHRoZSBlZmZlY3Qgb2YgdGFyZ2V0IGFnZSBvbiBtZW50YWwgY2FwYWNpdHkgYXR0cmlidXRpb25zIGRlZmluaXRlbHkgaGFzIGxpbmVhciwgcXVhZHJhdGljLCBhbmQgY3ViaWMgY29tcG9uZW50cywgYWxsIHRocmVlIG9mIHdoaWNoIHNlZW0gdG8gdmFyeSBzdWJzdGFudGlhbGx5IGFjcm9zcyBmYWN0b3JzLiBQcmV0dHkgbXVjaCBhbGwgb2YgdGhlc2UgZGlmZmVyZW5jZXMgYXJlICJzaWduaWZpY2FudCIgKGlmIHlvdSBjb25zaWRlciB8dHwgPiAyIHRvIGJlICJzaWduaWZpY2FudCIpIC0gZm9yIGludGVycHJldGF0aW9uLCBJIHdvdWxkIG5lZWQgdG8gbG9vayBjbG9zZXIgYXQgdGhlIHBsb3QuIExldCdzIHB1bGwgaXQgdXAgYWdhaW4gaGVyZSwgd2l0aCBibHVlIGxpbmVzIGFwcHJveGltYXRpbmcgdGhlIGZvcm11bGEgYHkgfiBwb2x5KHgsIDMpYDoKCmBgYHtyLCBmaWcud2lkdGggPSA0LCBmaWcuYXNwID0gMC43fQpzY29yZXNwbG90X2Z1bihlZmFfYWxsX3BhciwgdGFyZ2V0ID0gImFsbCAoc3R1ZHkgMikiLCAKICAgICAgICAgICAgICAgdGFyZ2V0X2VuY29kaW5nID0gIm51bWVyaWMiKSArCiAgc2NhbGVfeF9jb250aW51b3VzKCJhZ2UgKG1vbnRocykiLCBicmVha3MgPSBzZXEoMCwgNjAsIDEyKSkgKwogIGdlb21fc21vb3RoKG1ldGhvZCA9ICJsbSIsIGZvcm11bGEgPSAieSB+IHBvbHkoeCwgMykiLAogICAgICAgICAgICAgIGNvbG9yID0gImJsdWUiLCBzaXplID0gMikKYGBgCgpXZSBjYW4gdGFsayB0aHJvdWdoIHRoZXNlIGludGVycHJldGF0aW9ucyB0b2dldGhlciAtIGJ1dCBJIGZpbmQgdGhlIGRpZmZlcmVuY2UgYmV0d2VlbiBGYWN0b3IgMiAoImNvZ25pdGlvbiAmIGNvbnRyb2wiKSBhbmQgRmFjdG9yIDQgKCJwb3NpdGl2ZSBlbW90aW9ucyIpIHRvIGJlIGVzcGVjaWFsbHkgaW50ZXJlc3RpbmchCgoKIyBEZW1vZ3JhcGhpY3MKCmBgYHtyfQpnZ3Bsb3QoZF9kZW1vLCBhZXMoeCA9IER1cmF0aW9uLzYwKSkgKyAKICBnZW9tX2hpc3RvZ3JhbShiaW53aWR0aCA9IDIpICsKICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSBtZWRpYW4oZF9kZW1vJER1cmF0aW9uLzYwKSwgY29sb3IgPSAiYmx1ZSIsIGx0eSA9IDIpICsKICBzY2FsZV94X2NvbnRpbnVvdXMoYnJlYWtzID0gc2VxKDAsIDEwMDAwLCA0KSkgKwogIGxhYnModGl0bGUgPSAiRHVyYXRpb24gb2Ygc3R1ZHkgKGFjY29yZGluZyB0byBRdWFsdHJpY3MpIiwKICAgICAgIHN1YnRpdGxlID0gIkJsdWUgZG90dGVkIGxpbmUgbWFya3MgbWVkaWFuIiwKICAgICAgIHggPSAiRHVyYXRpb24gKGluIG1pbnV0ZXMpIiwKICAgICAgIHkgPSAiTnVtYmVyIG9mIHBhcnRpY2lwYW50cyIpCmBgYAoKYGBge3J9CmdncGxvdChkX2RlbW8sIGFlcyh4ID0gQWdlKSkgKyAKICBnZW9tX2hpc3RvZ3JhbShiaW53aWR0aCA9IDIpICsKICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSBtZWRpYW4oZF9kZW1vJEFnZSksIGNvbG9yID0gImJsdWUiLCBsdHkgPSAyKSArCiAgc2NhbGVfeF9jb250aW51b3VzKGJyZWFrcyA9IHNlcSgwLCAxMDAwMCwgNCkpICsKICBsYWJzKHRpdGxlID0gIlBhcnRpY3BpYW50IGFnZSAoc2VsZi1yZXBvcnRlZCkiLAogICAgICAgc3VidGl0bGUgPSAiQmx1ZSBkb3R0ZWQgbGluZSBtYXJrcyBtZWRpYW4iLAogICAgICAgeCA9ICJBZ2UgKGluIHllYXJzKSIsCiAgICAgICB5ID0gIk51bWJlciBvZiBwYXJ0aWNpcGFudHMiKQpgYGAKCmBgYHtyfQpnZ3Bsb3QoZF9kZW1vLCBhZXMoeCA9IEdlbmRlclNleCkpICsgCiAgZ2VvbV9iYXIoKSArCiAgbGFicyh0aXRsZSA9ICJQYXJ0aWNwaWFudCBnZW5kZXIvc2V4IChzZWxmLXJlcG9ydGVkKSIsCiAgICAgICB4ID0gIkdlbmRlci9zZXgiLAogICAgICAgeSA9ICJOdW1iZXIgb2YgcGFydGljaXBhbnRzIikKYGBgCgpgYGB7cn0KZ2dwbG90KGRfZGVtbywgYWVzKHggPSBnc3ViKCcoLnsxLDMwfSkoXFxzfCQpJywgJ1xcMVxuJywgUmFjZUV0aG5pY2l0eV9jb2xsYXBzZSkpKSArIAogIGdlb21fYmFyKCkgKwogIHRoZW1lKGF4aXMudGV4dC54ID0gZWxlbWVudF90ZXh0KGFuZ2xlID0gNDUsIGhqdXN0ID0gMSwgdmp1c3QgPSAxKSkgKwogIGxhYnModGl0bGUgPSAiUGFydGljcGlhbnQgcmFjZS9ldGhuaWNpdHkgKHNlbGYtcmVwb3J0ZWQpIiwKICAgICAgIHggPSAiUmFjZS9ldGhuaWNpdHkiLAogICAgICAgeSA9ICJOdW1iZXIgb2YgcGFydGljaXBhbnRzIikKYGBgCgpgYGB7cn0KZ2dwbG90KGRfZGVtbywgYWVzKHggPSBGaXJzdExhbmcpKSArIAogIGdlb21fYmFyKCkgKwogIGxhYnModGl0bGUgPSAiUGFydGljcGlhbnQgZmlyc3QgbGFuZ3VhZ2UgKHNlbGYtcmVwb3J0ZWQpIiwKICAgICAgIHggPSAiTGFuZ3VhZ2UiLAogICAgICAgeSA9ICJOdW1iZXIgb2YgcGFydGljaXBhbnRzIikKYGBgCgpgYGB7cn0KZ2dwbG90KGRfZGVtbywgYWVzKHggPSBmYWN0b3IoRWR1Y2F0aW9uLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsZXZlbHMgPSBsZXZlbHMoZCRFZHVjYXRpb24pLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICBsYWJlbHMgPSBnc3ViKCcoLnsxLDMwfSkoXFxzfCQpJywgJ1xcMVxuJywgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbGV2ZWxzKGQkRWR1Y2F0aW9uKSkpKSkgKyAKICBnZW9tX2JhcigpICsKICB0aGVtZShheGlzLnRleHQueCA9IGVsZW1lbnRfdGV4dChhbmdsZSA9IDQ1LCBoanVzdCA9IDEsIHZqdXN0ID0gMSkpICsKICBsYWJzKHRpdGxlID0gIlBhcnRpY3BpYW50IGVkdWNhdGlvbmFsIGF0dGFpbm1lbnQgKHNlbGYtcmVwb3J0ZWQpIiwKICAgICAgIHggPSAiSGlnaGVzdCBsZXZlbCBvZiBlZHVjYXRpb24gY29tcGxldGVkIiwKICAgICAgIHkgPSAiTnVtYmVyIG9mIHBhcnRpY2lwYW50cyIpCmBgYAoKYGBge3J9CmdncGxvdChkX2RlbW8sIGFlcyh4ID0gSW5jb21lKSkgKyAKICBnZW9tX2JhcigpICsKICB0aGVtZShheGlzLnRleHQueCA9IGVsZW1lbnRfdGV4dChhbmdsZSA9IDQ1LCBoanVzdCA9IDEsIHZqdXN0ID0gMSkpICsKICBsYWJzKHRpdGxlID0gIlBhcnRpY3BpYW50IGhvdXNlaG9sZCBpbmNvbWUgKHNlbGYtcmVwb3J0ZWQpIiwKICAgICAgIHggPSAiQW5udWFsIGhvdXNlaG9sZCBpbmNvbWUiLAogICAgICAgeSA9ICJOdW1iZXIgb2YgcGFydGljaXBhbnRzIikKYGBgCgpgYGB7cn0KZ2dwbG90KGRfZGVtbywgYWVzKHggPSBIb3VzZWhvbGRTaXplKSkgKyAKICBnZW9tX2hpc3RvZ3JhbShiaW53aWR0aCA9IDEpICsKICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSBtZWRpYW4oZF9kZW1vJEhvdXNlaG9sZFNpemUpLCBjb2xvciA9ICJibHVlIiwgbHR5ID0gMikgKwogIHNjYWxlX3hfY29udGludW91cyhicmVha3MgPSBzZXEoMCwgMTAwMDAsIDEpKSArCiAgbGFicyh0aXRsZSA9ICJQYXJ0aWNwaWFudCBob3VzZWhvbGQgc2l6ZSAoc2VsZi1yZXBvcnRlZCkiLAogICAgICAgc3VidGl0bGUgPSAiQmx1ZSBkb3R0ZWQgbGluZSBtYXJrcyBtZWRpYW4iLAogICAgICAgeCA9ICJOdW1iZXIgb2YgcGVvcGxlIGluIGhvdXNlaG9sZCAoYWR1bHRzIGFuZCBjaGlsZHJlbikiLAogICAgICAgeSA9ICJOdW1iZXIgb2YgcGFydGljaXBhbnRzIikKYGBgCgpgYGB7cn0KZ2dwbG90KGRfZGVtbywgYWVzKHggPSBNYXJpdGFsU3RhdHVzKSkgKyAKICBnZW9tX2JhcigpICsKICB0aGVtZShheGlzLnRleHQueCA9IGVsZW1lbnRfdGV4dChhbmdsZSA9IDQ1LCBoanVzdCA9IDEsIHZqdXN0ID0gMSkpICsKICBsYWJzKHRpdGxlID0gIlBhcnRpY3BpYW50IG1hcml0YWwgc3RhdHVzIChzZWxmLXJlcG9ydGVkKSIsCiAgICAgICB4ID0gIk1hcml0YWwgc3RhdHVzIiwKICAgICAgIHkgPSAiTnVtYmVyIG9mIHBhcnRpY2lwYW50cyIpCmBgYAoKYGBge3J9CmdncGxvdChkX2RlbW8sIGFlcyh4ID0gUGFyZW50KSkgKyAKICBnZW9tX2JhcigpICsKICB0aGVtZShheGlzLnRleHQueCA9IGVsZW1lbnRfdGV4dChhbmdsZSA9IDQ1LCBoanVzdCA9IDEsIHZqdXN0ID0gMSkpICsKICBsYWJzKHRpdGxlID0gIlBhcnRpY3BpYW50IHBhcmVudCBzdGF0dXMgKHNlbGYtcmVwb3J0ZWQpIiwKICAgICAgIHN1YnRpdGxlID0gIidOQScgaW5kaWNhdGVzIHJlc3BvbnNlIG9mICdQcmVmZXIgbm90IHRvIHNheSciLAogICAgICAgeCA9ICJQYXJlbnQgc3RhdHVzIiwKICAgICAgIHkgPSAiTnVtYmVyIG9mIHBhcnRpY2lwYW50cyIpCmBgYAoKYGBge3J9CmdncGxvdChkX2RlbW8gJT4lIGZpbHRlcihQYXJlbnQgPT0gIlllcyIpLCBhZXMoeCA9IENoaWxkcmVuTnVtYmVyKSkgKyAKICBnZW9tX2hpc3RvZ3JhbShiaW53aWR0aCA9IDEpICsKICBnZW9tX3ZsaW5lKHhpbnRlcmNlcHQgPSBtZWRpYW4oZF9kZW1vW2RfZGVtbyRQYXJlbnQgPT0gIlllcyIsXSRDaGlsZHJlbk51bWJlciwgbmEucm0gPSBUKSwgCiAgICAgICAgICAgICBjb2xvciA9ICJibHVlIiwgbHR5ID0gMikgKwogIHNjYWxlX3hfY29udGludW91cyhicmVha3MgPSBzZXEoMCwgMTAwMDAsIDEpKSArCiAgbGFicyh0aXRsZSA9ICJOdW1iZXIgb2YgY2hpbGRyZW4gYW1vbmcgcGFyZW50cyAoc2VsZi1yZXBvcnRlZCkiLAogICAgICAgc3VidGl0bGUgPSAiQmx1ZSBkb3R0ZWQgbGluZSBtYXJrcyBtZWRpYW4iLAogICAgICAgeCA9ICJOdW1iZXIgb2YgY2hpbGRyZW4gKGFtb25nIHBhcmVudHMpIiwKICAgICAgIHkgPSAiTnVtYmVyIG9mIHBhcnRpY2lwYW50cyIpCmBgYAoKYGBge3J9CmdncGxvdChkX2RlbW8gJT4lIGZpbHRlcihQYXJlbnQgPT0gIlllcyIpLCAKICAgICAgIGFlcyh4ID0gZmFjdG9yKENoaWxkcmVuT2xkZXN0QWdlX2NvbGxhcHNlLAogICAgICAgICAgICAgICAgICAgICAgbGV2ZWxzID0gbGV2ZWxzKGRfZGVtbyRDaGlsZHJlbk9sZGVzdEFnZV9jb2xsYXBzZSksCiAgICAgICAgICAgICAgICAgICAgICBsYWJlbHMgPSBnc3ViKCcoLnsxLDMwfSkoXFxzfCQpJywgJ1xcMVxuJywgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxldmVscyhkX2RlbW8kQ2hpbGRyZW5PbGRlc3RBZ2VfY29sbGFwc2UpKSkpKSArIAogIGdlb21fYmFyKCkgKwogIHRoZW1lKGF4aXMudGV4dC54ID0gZWxlbWVudF90ZXh0KGFuZ2xlID0gNDUsIGhqdXN0ID0gMSwgdmp1c3QgPSAxKSkgKwogIGxhYnModGl0bGUgPSAiQWdlIG9mIG9sZGVzdCBjaGlsZCBhbW9uZyBwYXJlbnRzIChzZWxmLXJlcG9ydGVkKSIsCiAgICAgICB4ID0gIkFnZSBvZiBjaGlsZCBpbiB5ZWFycyAoYW1vbmcgcGFyZW50cykiLAogICAgICAgeSA9ICJOdW1iZXIgb2YgcGFydGljaXBhbnRzIikKYGBgCgpgYGB7cn0KZ2dwbG90KGRfZGVtbyAlPiUgZmlsdGVyKFBhcmVudCA9PSAiWWVzIiksIAogICAgICAgYWVzKHggPSBmYWN0b3IoQ2hpbGRyZW5Zb3VuZ2VzdEFnZV9jb2xsYXBzZSwKICAgICAgICAgICAgICAgICAgICAgIGxldmVscyA9IGxldmVscyhkX2RlbW8kQ2hpbGRyZW5Zb3VuZ2VzdEFnZV9jb2xsYXBzZSksCiAgICAgICAgICAgICAgICAgICAgICBsYWJlbHMgPSBnc3ViKCcoLnsxLDMwfSkoXFxzfCQpJywgJ1xcMVxuJywgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxldmVscyhkX2RlbW8kQ2hpbGRyZW5Zb3VuZ2VzdEFnZV9jb2xsYXBzZSkpKSkpICsgCiAgZ2VvbV9iYXIoKSArCiAgdGhlbWUoYXhpcy50ZXh0LnggPSBlbGVtZW50X3RleHQoYW5nbGUgPSA0NSwgaGp1c3QgPSAxLCB2anVzdCA9IDEpKSArCiAgbGFicyh0aXRsZSA9ICJBZ2Ugb2YgeW91bmdlc3QgY2hpbGQgYW1vbmcgcGFyZW50cyAoc2VsZi1yZXBvcnRlZCkiLAogICAgICAgeCA9ICJBZ2Ugb2YgY2hpbGQgaW4geWVhcnMgKGFtb25nIHBhcmVudHMpIiwKICAgICAgIHkgPSAiTnVtYmVyIG9mIHBhcnRpY2lwYW50cyIpCmBgYAoKCg==